

### Low-Power, Integrated UHF Receiver

### **Features**

- · High Sensitivity:
  - down to -120 dBm at 1.2 kbps
- · High Selectivity:
  - 16-Tap FIR channel filter
- · Bullet-Proof Front End:
  - IIP3 = -18 dBm, IIP2 = +35 dBm, 80 dB blocking immunity, no image frequency response
- · Low Current:
  - Rx = 16 mA, 100 nA register retention
- Constant RF Performance over Voltage Range of Chip
- · FSK Bit Rates up to 300 kbps
- Fully Integrated Synthesizer with a Resolution of 61 Hz
- FSK, GFSK, MSK, GMSK and OOK Demodulation
- Built-in Bit Synchronizer Performing Clock Recovery
- Incoming Sync Word Recognition
- 115 dB+ Dynamic Range Received Signal Strength Indicator (RSSI)
- Automatic RF Sense with Ultra-Fast Automatic Frequency Control (AFC)
- Packet Engine with CRC, AES-128 Encryption and 66-Byte First In First Out (FIFO)
- Built-in Temperature Sensor and Low-Battery Indicator

### **General Description**

The MRF39RA device is a highly integrated RF receiver capable of operation over a wide frequency range, including the 433, 868 and 915 MHz license-free Industry Scientific and Medical (ISM) frequency bands. Its highly integrated architecture allows for a minimum of external components while maintaining maximum design flexibility. All major RF communication parameters are programmable and most of them can be dynamically set. The MRF39RA offers the unique advantage of programmable narrow-band and wide-band communication modes without the need of modifying external components. MRF39RA is optimized for low-power consumption while offering high sensitivity and channelized operation. TrueRF™ technology enables a low-cost external component count (elimination of the SAW filter) while still satisfying the European

Telecommunications Standards Institute (ETSI) and Federal Communications Commission (FCC) regulations.

FIGURE 1: MRF39RA RECEIVER:
LOW-POWER INTEGRATED
UHF RECEIVER



### **Typical Applications**

- · Automated Meter Reading
- · Wireless Sensor Networks
- Home and Building Automation
- Wireless Alarm and Security Systems
- · Industrial Monitoring and Control
- · Wireless M-Bus

### Pin Diagram

### FIGURE 2: 24-PIN QFN



### **Markets**

- Europe: EN 300-220-1
- North America: FCC Part 15.247, 15.249, 15.231
- · Narrow Korean and Japanese Bands

### **Table of Contents**

| 1.0   | Overview                           | 3  |
|-------|------------------------------------|----|
| 2.0   | Device Description                 |    |
| 3.0   | Operating Modes                    |    |
| 4.0   | Data Processing                    |    |
| 5.0   | Configuration and Status Registers |    |
| 6.0   | Application Information            |    |
| 7.0   | Electrical Specifications          | 59 |
| 8.0   | Packaging Information              | 63 |
| The N | Microchip Web Site                 | 69 |
|       | omer Change Notification Service   |    |
| Custo | omer Support                       | 69 |
|       | uct Identification System          |    |

### TO OUR VALUED CUSTOMERS

It is our intention to provide our valued customers with the best documentation possible to ensure successful use of your Microchip products. To this end, we will continue to improve our publications to better suit your needs. Our publications will be refined and enhanced as new volumes and updates are introduced.

If you have any questions or comments regarding this publication, please contact the Marketing Communications Department via E-mail at docerrors@microchip.com. We welcome your feedback.

### **Most Current Data Sheet**

To obtain the most up-to-date version of this data sheet, please register at our Worldwide Web site at:

#### http://www.microchip.com

You can determine the version of a data sheet by examining its literature number found on the bottom outside corner of any page. The last character of the literature number is the version number, (e.g., DS30000000A is version A of document DS30000000).

#### **Errata**

An errata sheet, describing minor operational differences from the data sheet and recommended workarounds, may exist for current devices. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision of silicon and revision of document to which it applies.

To determine if an errata sheet exists for a particular device, please check with one of the following:

- Microchip's Worldwide Web site; http://www.microchip.com
- Your local Microchip sales office (see last page)

When contacting a sales office, please specify which device, revision of silicon and data sheet (include literature number) you are using.

### **Customer Notification System**

Register on our web site at www.microchip.com to receive the most current information on all of our products.

### 1.0 OVERVIEW

The MRF39RA is a single-chip integrated circuit ideally suited for today's high-performance ISM band RF applications. The MRF39RA's advanced features set, including state-of-the-art packet engine, greatly simplifies system design while the high level of integration reduces the external bill of materials (BOM) to a handful of passive decoupling and matching components. It is intended for use as a high-performance, low-cost FSK and OOK RF receiver for robust frequency agile RF links, and where stable and constant RF performance is required over the full operating range of the device down to 1.8V.

The MRF39RA is intended for applications over a wide frequency range, including the 433 MHz and 868 MHz European and 902-928 MHz North American ISM bands. Coupled with a very aggressive sensitivity, the advanced system features of the MRF39RA include a 66-byte RX FIFO, configurable automatic packet handler, Listen mode, temperature sensor and configurable DIOs, which greatly enhance system flexibility while significantly reducing MCU requirements at the same time.

The MRF39RA complies with both ETSI and FCC regulatory requirements and is available in a 5 x 5 mm 24-lead QFN package.

FIGURE 1-1: SIMPLIFIED BLOCK DIAGRAM



TABLE 1-1: MRF39RA PINOUTS

| Number | Nama      | Tymo         | Description                                     |  |
|--------|-----------|--------------|-------------------------------------------------|--|
| Number | Name      | Туре         | Description                                     |  |
| 0      | GROUND    | _            | Exposed Ground Pad                              |  |
| 1      | VBAT1     | <del>-</del> | Supply Voltage                                  |  |
| 2      | VR_ANA    | _            | Regulated Supply Voltage for Analogue Circuitry |  |
| 3      | VR_DIG    | _            | Regulated Supply Voltage for Digital Blocks     |  |
| 4      | XTA       | I/O          | XTAL Connection                                 |  |
| 5      | XTB       | I/O          | XTAL Connection                                 |  |
| 6      | RESET     | I/O          | Reset Trigger Input                             |  |
| 7      | DIO0      | I/O          | Digital I/O, Software Configured                |  |
| 8      | DIO1/DCLK | 0            | Digital Output, Software Configured             |  |
| 9      | DIO2/DATA | 0            | Digital Output, Software Configured             |  |
| 10     | DIO3      | I/O          | Digital I/O, Software Configured                |  |
| 11     | DIO4      | I/O          | Digital I/O, Software Configured                |  |
| 12     | DIO5      | I/O          | Digital I/O, Software Configured                |  |
| 13     | VBAT2     | _            | Supply Voltage                                  |  |
| 14     | GND       | _            | Ground                                          |  |
| 15     | SCK       | I            | SPI Clock Input                                 |  |
| 16     | MISO      | 0            | SPI Data Output                                 |  |
| 17     | MOSI      | I            | SPI Data Input                                  |  |
| 18     | NSS       | I            | SPI Chip Select Input                           |  |
| 19     | NC        | _            | Do not connect                                  |  |
| 20     | GND       | _            | Ground                                          |  |
| 21     | RFIN      | I            | RF Input                                        |  |
| 22     | GND       | _            | Ground                                          |  |
| 23     | NC        | _            | Do not connect                                  |  |
| 24     | NC        | _            | Do not connect                                  |  |

### 2.0 DEVICE DESCRIPTION

This section describes in depth the architecture of the MRF39RA low-power, highly integrated receiver.

### 2.1 Power Supply Strategy

The MRF39RA employs an advanced power supply scheme, which provides stable operating characteristics over the full temperature and voltage range of operation.

The MRF39RA can be powered from any low-noise voltage source via pins VBAT1 and VBAT2. As suggested in the reference design, decoupling capacitors should be connected on VR\_DIG and VR\_ANA pins to ensure a correct operation of the built-in voltage regulators.

### 2.2 Low Battery Detector

A low battery detector is also included allowing the generation of an interrupt signal in response to passing a programmable threshold adjustable through the RegLowBat register. The interrupt signal can be mapped to any of the DIO pins, through the programming of RegDioMapping.

### 2.3 Frequency Synthesis

The LO generation on the MRF39RA is based on a state-of-the-art fractional-N PLL. The PLL is fully integrated with automatic calibration.

### 2.3.1 REFERENCE OSCILLATOR

The crystal oscillator is the main timing reference of the MRF39RA. It is used as a reference for the frequency synthesizer and as a clock for the digital processing.

The XO start-up time, TS\_OSC, depends on the actual XTAL being connected on pins XTA and XTB. When using the built-in sequencer, the MRF39RA optimizes the start-up time and automatically triggers the PLL when the XO signal is stable. To manually control the start-up time, the user should either wait for TS\_OSC max, or monitor the signal CLKOUT which will only be made available on the output buffer when a stable XO oscillation is achieved.

An external clock can be used to replace the crystal oscillator, for instance a tight tolerance TCXO. To do so, bit 4 at address 0x59 should be set to '1', and the external clock has to be provided on XTA (pin 4). XTB (pin 5) should be left open. The peak-peak amplitude of the input signal must never exceed 1.8V. Please consult the TCXO supplier for an appropriate value of decoupling capacitor, CD.

### FIGURE 2-1: TCXO CONNECTION



### 2.3.2 CLKOUT OUTPUT

The reference frequency, or a fraction of it, can be provided on DIO5 (pin 12) by modifying bits ClkOut in RegDioMapping2. Two typical applications of the CLKOUT output include:

- Providing a clock output for a companion processor, thus saving the cost of an additional oscillator; CLKOUT can be made available in any operation mode except Sleep mode and is automatically enabled at Power-on Reset
- Providing an oscillator reference output; measurement of the CLKOUT signal enables simple software trimming of the initial crystal tolerance

**Note:** To minimize the current consumption of the MRF39RA, please ensure that the CLKOUT signal is disabled when not required.

#### 2.3.3 PLL ARCHITECTURE

The frequency synthesizer generating the LO frequency for the receiver is a fractional-N sigma-delta PLL. The PLL incorporates a third-order loop capable of fast auto-calibration, and it has a fast switching time. The VCO and the loop filter are both fully integrated, removing the need for an external tight-tolerance, high-Q inductor in the VCO tank circuit.

### 2.3.3.1 VCO

The VCO runs at two, four or six times the RF frequency (respectively in the 915, 434 and 315 MHz bands) to reduce any LO leakage in Receiver mode, to improve the quadrature precision of the receiver.

The VCO calibration is fully automated. A coarse adjustment is carried out at Power-on Reset, and a fine tuning is performed each time the MRF39RA PLL is activated. Automatic calibration times are fully transparent to the end user, as their processing time is included in the TS RE specifications.

### 2.3.3.2 PLL Bandwidth

The bandwidth of the MRF39RA Fractional-N PLL is wide enough to allow for very fast PLL lock times, enabling both short start-up and fast hop times required for frequency-agile applications.

### 2.3.3.3 Carrier Frequency and Resolution

The MRF39RA PLL embeds a 19-bit sigma-delta modulator and its frequency resolution, constant over the whole frequency range (see Equation 2-1).

## EQUATION 2-1: CARRIER FREQUENCY STEP

$$F_{STEP} = \frac{F_{XOSC}}{2^{19}}$$

The carrier frequency is programmed through RegFrf, split across addresses 0x07 to 0x09:

### **EQUATION 2-2: CARRIER FREQUENCY**

$$F_{RF} = F_{STEP} \times Frf(23,0)$$

Note: The Frf setting is split across three bytes. A change in the center frequency will only be taken into account when the Least Significant Byte FrfLsb in RegFrfLsb is written.

### 2.3.4 LOCK TIME

PLL lock time TS\_FS is a function of a number of technical factors, such as synthesized frequency, frequency step, etc. When using the built-in sequencer, the MRF39RA optimizes the start-up time and automatically starts the receiver when the PLL has locked. To manually control the start-up time, the user should either wait for TS\_FS max, given in the specification, or monitor the signal PLL lock detect indicator, which is set when the PLL is within its locking range.

When performing an AFC, which usually corrects very small frequency errors, the PLL response time is as shown in Equation 2-3 below.

### **EQUATION 2-3:**

$$T_{PLLAFC} = \frac{5}{PLLBW}$$

In a frequency hopping scheme, the TS\_HOP timings in Table 7-4 give an order of magnitude for the expected lock times.

### 2.3.5 LOCK DETECT INDICATOR

A lock indication signal can be made available on some of the DIO pins, which is toggled high when the PLL reaches its locking range. Please refer to Table 4-2 and Table 4-3 to map this interrupt to the desired pins.

### 2.4 Receiver Description

The MRF39RA features a digital receiver with the Analog-to-Digital conversion process being performed directly following the LNA-mixers block. The zero-IF receiver is able to handle (G)FSK and (G)MSK modulation. ASK and OOK modulation is, however, demodulated by a low-IF architecture. All the filtering, demodulation, gain control, synchronization and packet handling is performed digitally, which allows a very wide range of bit rates and frequency deviations to be selected. The receiver is also capable of automatic gain calibration in order to improve precision on RSSI measurements.

FIGURE 2-2: RECEIVER BLOCK DIAGRAM



The following sections give a brief description of each of the receiver blocks.

## 2.4.1 LNA – SINGLE-TO-DIFFERENTIAL BUFFER

The LNA uses a common-gate topology, which allows for a flat characteristic over the whole frequency range. It is designed to have an input impedance of 50 Ohms or 200 Ohms (as selected with bit LnaZin in RegLna), and the parasitic capacitance at the LNA input port is canceled with the external RF choke. A single-to-differential buffer is implemented to improve the second order linearity of the receiver.

The LNA gain, including the single-to-differential buffer, is programmable over a 48 dB dynamic range, and control is either manual or automatic with the embedded AGC function.

Note:

In the specific case where the LNA gain is manually set by the user, the receiver will not be able to properly handle FSK signals with a modulation index smaller than 2 at an input power greater than the 1 dB compression point, tabulated in Section 2.4.2 "Automatic Gain Control".

TABLE 2-1: LNA GAIN SETTINGS

| LnaGainSelect | LNA Gain                              | Gain<br>Setting |
|---------------|---------------------------------------|-----------------|
| 000           | Any of the below, set by the AGC loop | _               |
| 001           | Max gain                              | G1              |
| 010           | Max gain – 6 dB                       | G2              |
| 011           | Max gain – 12 dB                      | G3              |
| 100           | Max gain – 24 dB                      | G4              |
| 101           | Max gain – 36 dB                      | G5              |
| 110           | Max gain – 48 dB                      | G6              |
| 111           | Reserved                              | _               |

### 2.4.2 AUTOMATIC GAIN CONTROL

By default (LnaGainSelect = 000), the LNA gain is controlled by a digital AGC loop in order to obtain the optimal sensitivity/linearity trade-off.

Regardless of the Data Transfer mode (Packet or Continuous), the following series of events takes place when the receiver is enabled:

- The receiver stays in Wait mode, until RssiValue exceeds RssiThreshold for two consecutive samples. Its power consumption is the receiver power consumption.
- When this condition is satisfied, the receiver automatically selects the most suitable LNA gain, optimizing the sensitivity/linearity trade-off.
- The programmed LNA gain, read-accessible with LnaCurrentGain in RegLna, is carried on for the whole duration of the packet, until one of the following conditions is fulfilled:
- Packet mode: if AutoRxRestartOn = 0, the LNA gain will remain the same for the reception of the following packet. If AutoRxRestartOn = 1, after the controller has emptied the FIFO the receiver will re-enter the Wait mode described above, after a delay of InterPacketRxDelay, allowing for the distant transmitter to ramp down, hence avoiding a false RSSI detection. In both cases (AutoRxRestartOn = 0 or AutoRxRestartOn = 1), the receiver can also re-enter the Wait mode by setting RestartRx bit to '1'. The user can decide to do so in order to manually launch a new AGC procedure.
- Continuous mode: upon reception of valid data, the user can decide to either leave the receiver enabled with the same LNA gain, or to restart the procedure, by setting RestartRx bit to '1', resuming the Wait mode of the receiver, described above.

- **Note 1:** The AGC procedure must be performed while receiving preamble in FSK mode.
  - 2: In OOK mode, the AGC will give better results if performed while receiving a constant '1' sequence.

Figure 2-3 illustrates the AGC behavior.

FIGURE 2-3: AGC THRESHOLDS SETTINGS



Table 2-2 summarizes the performance (typical figures) of the complete receiver.

TABLE 2-2: RECEIVER PERFORMANCE SUMMARY

| Innut Power                   | Coin            | Receiver Performance (typ.) |            |               |               |
|-------------------------------|-----------------|-----------------------------|------------|---------------|---------------|
| Input Power Pin               | Gain<br>Setting | P <sub>-1dB</sub><br>[dBm]  | NF<br>[dB] | IIP3<br>[dBm] | IIP2<br>[dBm] |
| Pin < AgcThresh1              | G1              | -37                         | 7          | -18           | +35           |
| AgcThresh1 < Pin < AgcThresh2 | G2              | -31                         | 13         | -15           | +40           |
| AgcThresh2 < Pin < AgcThresh3 | G3              | -26                         | 18         | -8            | +48           |
| AgcThresh3 < Pin < AgcThresh4 | G4              | -14                         | 27         | -1            | +62           |
| AgcThresh4 < Pin < AgcThresh5 | G5              | >-6                         | 36         | +13           | +68           |
| AgcThresh5 < Pin              | G6              | >0                          | 44         | +20           | +75           |

### 2.4.2.1 RssiThreshold Setting

For correct operation of the AGC, RssiThreshold in RegRssiThresh must be set to the sensitivity of the receiver. The receiver will remain in Wait mode until RssiThreshold is exceeded.

Note:

When AFC is enabled and performed automatically at the receiver start-up, the channel filter used by the receiver during the AFC and AGC is RxBwAfc instead of the standard RxBw setting. This may impact the sensitivity of the receiver and the setting of RssiThreshold accordingly.

### 2.4.2.2 AGC Reference

The AGC reference level is automatically computed in the MRF39RA, according to the formula in Equation 2-4.

### **EQUATION 2-4:**

 $AGC\ Reference\ [dBm] = -174 + NF + DemoSnr + 10.log(2*RxBw) + FadingMargin[dBm]$ 

Where:

NF = 7 dB : LNA's Noise Figure at maximum gain
DemodSnr = 8 dB : SNR needed by the demodulator

RxBw : Single sideband channel filter bandwidth

FadingMargin = 5 dB : Fading margin

#### 2.4.3 CONTINUOUS-TIME DAGC

In addition to the automatic gain control described in Section 2.4.2 "Automatic Gain Control", the MRF39RA is capable of continuously adjusting its gain in the digital domain, after the Analog-to-Digital conversion has occurred. This feature, named DAGC, is fully transparent to the end user. The digital gain adjustment is repeated every two bits and has the following benefits:

- · Fully transparent to the end user
- Improves the fading margin of the receiver during the reception of a packet, even if the gain of the LNA is frozen
- Improves the receiver robustness in fast fading signal conditions by quickly adjusting the receiver gain (every two bits)
- Works in Continuous, Packet and Unlimited Length Packet modes

The DAGC is enabled by setting RegTestDagc to 0x20 for low modulation index systems (i.e., when AfcLowBetaOn = '1') (see Section 2.4.17 "Optimized Setup for Low Modulation Index Systems"), and 0x30 for other systems. It is recommended to always enable the DAGC.

## 2.4.4 QUADRATURE MIXER – ADCs – DECIMATORS

The mixer is inserted between the output of the RF buffer stage and the input of the Analog-to-Digital Converter (ADC) of the receiver section. This block is designed to translate the spectrum of the input RF signal to base-band, and offer both high IIP2 and IIP3 responses.

In the lower bands of operation (290 to 510 MHz), the multi-phase mixing architecture with weighted phases improves the rejection of the LO harmonics in Receiver mode, hence increasing the receiver immunity to out-of-band interferers.

The I and Q digitalization is made by two 5th order continuous-time sigma-delta Analog-to-Digital Converters (ADC). Their gain is not constant over temperature, but the whole receiver is calibrated before reception, so that this inaccuracy has no impact on the RSSI precision. The ADC output is one bit per channel. It needs to be decimated and filtered afterwards. This ADC can also be used for temperature measurement. Refer to Section 2.4.18 "Temperature Sensor" for more details.

The decimators decrease the sample rate of the incoming signal in order to optimize the area and power consumption of the following receiver blocks.

### 2.4.5 CHANNEL FILTER

The role of the channel filter is to filter out the noise and interferers outside of the channel. Channel filtering on the MRF39RA is implemented with a 16-tap finite impulse response (FIR) filter, providing an outstanding adjacent channel rejection performance, even for narrow-band applications.

Note: To respect oversampling rules in the decimation chain of the receiver, the bit rate cannot be set at a higher value than two times the single-side receiver

bandwidth (BitRate < 2 x RxBw)

The single-side channel filter bandwidth RxBw is controlled by the RxBwMant and RxBwExp parameters in RegRxBw, as shown in Equation 2-5 below.

### **EQUATION 2-5:**

When FSK modulation is enabled:

$$RxBw = \frac{FXOSC}{RxBwMant \times 2^{RxBwExp + 2}}$$

When OOK modulation is enabled:

$$RxBw = \frac{FXOSC}{RxBwMant \times 2^{RxBwExp + 3}}$$

Table 2-3 lists the accessible channel filter bandwidths (oscillator is mandated at 32 MHz).

TABLE 2-3: AVAILABLE RxBw SETTINGS

| D. D. Marit                | D. D                 | RxBw                       | (kHz)                      |
|----------------------------|----------------------|----------------------------|----------------------------|
| RxBwMant<br>(binary/value) | RxBwExp<br>(decimal) | FSK<br>ModulationType = 00 | OOK<br>ModulationType = 01 |
| 10b/24                     | 7                    | 2.6                        | 1.3                        |
| 01b/20                     | 7                    | 3.1                        | 1.6                        |
| 00b/16                     | 7                    | 3.9                        | 2.0                        |
| 10b/24                     | 6                    | 5.2                        | 2.6                        |
| 01b/20                     | 6                    | 6.3                        | 3.1                        |
| 00b/16                     | 6                    | 7.8                        | 3.9                        |
| 10b/24                     | 5                    | 10.4                       | 5.2                        |
| 01b/20                     | 5                    | 12.5                       | 6.3                        |
| 00b/16                     | 5                    | 15.6                       | 7.8                        |
| 10b/24                     | 4                    | 20.8                       | 10.4                       |
| 01b/20                     | 4                    | 25.0                       | 12.5                       |
| 00b/16                     | 4                    | 31.3                       | 15.6                       |
| 10b/24                     | 3                    | 41.7                       | 20.8                       |
| 01b/20                     | 3                    | 50.0                       | 25.0                       |
| 00b/16                     | 3                    | 62.5                       | 31.3                       |
| 10b/24                     | 2                    | 83.3                       | 41.7                       |
| 01b/20                     | 2                    | 100.0                      | 50.0                       |
| 00b/16                     | 2                    | 125.0                      | 62.5                       |
| 10b/24                     | 1                    | 166.7                      | 83.3                       |
| 01b/20                     | 1                    | 200.0                      | 100.0                      |
| 00b/16                     | 1                    | 250.0                      | 125.0                      |
| 10b/24                     | 0                    | 333.3                      | 166.7                      |
| 01b/20                     | 0                    | 400.0                      | 200.0                      |
| 00b/16                     | 0                    | 500.0                      | 250.0                      |

### 2.4.6 DC CANCELLATION

DC cancellation is required in zero-IF architecture transceivers to remove any DC offset generated through self-reception. It is built in the MRF39RA and its adjustable cutoff frequency (fc) is controlled in RegRxBw.

TABLE 2-4: AVAILABLE DCC CUTOFF FREQUENCIES

| DccFreq in RegRxBw | fc in % of RxBw |
|--------------------|-----------------|
| 000                | 16              |
| 001                | 8               |
| 010 (default)      | 4               |
| 011                | 2               |
| 100                | 1               |
| 101                | 0.5             |
| 110                | 0.25            |
| 111                | 0.125           |

The default value of DccFreq cutoff frequency is typically 4% of the RxBw (channel filter BW). The cutoff frequency of the DCC can however be increased to slightly improve the sensitivity, under wider modulation conditions. It is advised to adjust the DCC setting while monitoring the receiver sensitivity.

### 2.4.7 COMPLEX FILTER - OOK

In OOK mode the MRF39RA is modified to a low-IF architecture. The IF frequency is automatically set to half the single-side bandwidth of the channel filter (FIF =  $0.5 \times RxBw$ ). The Local Oscillator is automatically offset by the IF in the OOK receiver. A complex filter is implemented on the chip to attenuate the resulting image frequency by typically 30 dB.

**Note:** This filter is automatically bypassed when receiving FSK signals (ModulationType = 00 in RegDataModul).

#### 2.4.8 **RSSI**

The RSSI block evaluates the amount of energy available within the receiver channel bandwidth. Its resolution is 0.5 dB, and it has a wide dynamic range to accommodate both small and large signal levels that may be present. Its acquisition time is very short, taking only 2-bit periods. The RSSI sampling must occur during the reception of preamble in FSK and constant '1' reception in OOK.

- Note 1: RssiValue can only be read when it exceeds RssiThreshold.
  - 2: RssiStart command and RssiDone flags are not usable when DAGC is turned on. See Section 2.4.3 "Continuous-Time DAGC".
  - **3:** The receiver is capable of automatic gain calibration, in order to improve the precision of its RSSI measurements. This function injects a known RF signal at the LNA input and calibrates the receiver gain accordingly. This calibration is automatically performed during the PLL start-up, making it a transparent process to the end user.
  - 4: RSSI accuracy depends components located between antenna port and pin RFIO and is therefore limited to a few decibels. Board-level calibration is advised to further improve accuracy.

#### FIGURE 2-4: **RSSI DYNAMIC CURVE**



### 2.4.9 CORDIC

The Cordic task is to extract the phase and the amplitude of the modulation vector (I + j.Q). The following information is used, still in the digital domain:

- Phase output: used by the FSK demodulator and the AFC blocks
- Amplitude output: used by the RSSI block for FSK demodulation, AGC and automatic gain calibration purposes

FIGURE 2-5: CORDIC EXTRACTION



### 2.4.10 BIT RATE SETTING

The bit rate (BR) is controlled by the BitRate bits in RegBitrate, as shown in Equation 2-6 below.

### **EQUATION 2-6:**

$$BR = \frac{F_{XOSC}}{BitRate}$$

Table 2-5 lists some of the accessible bit rates.

TABLE 2-5: BIT RATE EXAMPLES

| Туре                                | BitRate<br><15:8> | BitRate<br><7:0> | (G)FSK<br>(G)MSK | оок         | Actual BR (b/s) |
|-------------------------------------|-------------------|------------------|------------------|-------------|-----------------|
| Classical Modem Baud Rates          | 0x68              | 0x2B             | 1.2 kbps         | 1.2 kbps    | 1200.015        |
| (multiples of 1.2 kbps)             | 0x34              | 0x15             | 2.4 kbps         | 2.4 kbps    | 2400.060        |
|                                     | 0x1A              | 0x0B             | 4.8 kbps         | 4.8 kbps    | 4799.760        |
|                                     | 0x0D              | 0x05             | 9.6 kbps         | 9.6 kbps    | 9600.960        |
|                                     | 0x06              | 0x83             | 19.2 kbps        | 19.2 kbps   | 19196.16        |
|                                     | 0x03              | 0x41             | 38.4 kbps        | _           | 38415.36        |
|                                     | 0x01              | 0xA1             | 76.8 kbps        | _           | 76738.60        |
|                                     | 0x00              | 0xD0             | 153.6 kbps       | _           | 153846.1        |
| Classical Modem Baud Rates          | 0x02              | 0x2C             | 57.6 kbps        | _           | 57553.95        |
| (multiples of 0.9 kbps)             | 0x01              | 0x16             | 115.2 kbps       |             | 115107.9        |
| Round Bit Rates                     | 0x0A              | 0x00             | 12.5 kbps        | 12.5 kbps   | 12500.00        |
| (multiples of 12.5, 25 and 50 kbps) | 0x05              | 0x00             | 25 kbps          | 25 kbps     | 25000.00        |
|                                     | 0x02              | 0x80             | 50 kbps          |             | 50000.00        |
|                                     | 0x01              | 0x40             | 100 kbps         | _           | 100000.0        |
|                                     | 0x00              | 0xD5             | 150 kbps         | _           | 150234.7        |
|                                     | 0x00              | 0xA0             | 200 kbps         | _           | 200000.0        |
|                                     | 0x00              | 0x80             | 250 kbps         | _           | 250000.0        |
|                                     | 0x00              | 0x6B             | 300 kbps         | _           | 299065.4        |
| Watch Xtal Frequency                | 0x03              | 0xD1             | 32.768 kbps      | 32.768 kbps | 32753.32        |

### 2.4.11 FSK DEMODULATOR

The FSK demodulator of the MRF39RA is designed to demodulate FSK, GFSK, MSK and GMSK modulated signals. It is most efficient when the modulation index of the signal is greater than 0.5 and below 10 (see Equation 2-7).

### **EQUATION 2-7:**

$$0.5 \le \beta = \frac{2 \times F_{DEV}}{BR} \le 10$$

The output of the FSK demodulator can be fed to the bit synchronizer (described in **Section 2.4.14 "Bit Synchronizer"**), to provide the companion processor with a synchronous data stream in Continuous mode.

### 2.4.12 OOK DEMODULATOR

The OOK demodulator performs a comparison of the RSSI output and a threshold value. Three different threshold modes are available, configured through bits OokThreshType in RegOokPeak.

The recommended mode of operation is the Peak Threshold mode, illustrated in Figure 2-6.

### FIGURE 2-6: OOK PEAK DEMODULATOR DESCRIPTION



In Peak Threshold mode the comparison threshold level is the peak value of the RSSI, reduced by 6 dB. In the absence of an input signal, or during the reception of a logical '0', the acquired peak value is decremented by one OokPeakThreshStep every OokPeakThreshDec period.

When the RSSI output is null for a long time (for instance after a long string of '0' received, or if no transmitter is present), the peak threshold level will continue falling until it reaches the Floor Threshold, programmed in OokFixedThresh.

The default settings of the OOK demodulator lead to the performance stated in the electrical specification. However, in applications in which sudden signal drops are awaited during a reception, the three parameters should be optimized accordingly.

## 2.4.13 OPTIMIZING THE FLOOR THRESHOLD

OokFixedThresh determines the sensitivity of the OOK receiver, as it sets the comparison threshold for weak input signals (i.e., those close to the noise floor). Significant sensitivity improvements can be generated if configured correctly.

Note that the noise floor of the receiver at the demodulator input depends on:

- · The noise figure of the receiver
- The gain of the receive chain from antenna to base band
- The matching, including SAW filter (if any)
- · The bandwidth of the channel filters

It is therefore important to note that the setting of OokFixedThresh will be application-dependent. The following procedure is recommended to optimize OokFixedThresh.

FIGURE 2-7: FLOOR THRESHOLD OPTIMIZATION



The new floor threshold value found during this test should be used for OOK reception with those receiver settings.

### 2.4.13.1 Optimizing OOK Demodulator for Fast Fading Signals

A sudden drop in signal strength can cause the bit error rate to increase. For applications where the expected signal drop can be estimated, the OokPeakThreshStep and OokPeakThreshDec parameters can be optimized for a given number of threshold decrements per bit. Refer to RegOokPeak to access those settings.

## 2.4.13.2 Alternative OOK Demodulator Threshold Modes

In addition to the Peak OOK Threshold mode, the user can alternatively select two other types of threshold detectors:

- Fixed Threshold: the value is selected through OokFixedThresh
- Average Threshold: data supplied by the RSSI block is averaged and this operation mode should only be used with DC-free encoded data

### 2.4.14 BIT SYNCHRONIZER

The bit synchronizer is a block that provides a clean and synchronized digital output, free of glitches. Its output is made available on pin DIO1/DCLK in Continuous mode and can be disabled through register settings. However, for optimum receiver performance its use when running Continuous mode is strongly advised.

The bit synchronizer is automatically activated in Packet mode. Its bit rate is controlled by BitRateMsb and BitRateLsb in RegBitrate.

FIGURE 2-8: BIT SYNCHRONIZER DESCRIPTION



To ensure correct operation of the bit synchronizer, the following conditions have to be satisfied:

- A preamble (0x55 or 0xAA) of at least 12 bits is required for synchronization; the longer the synchronization, the better the packet success rate
- The subsequent payload bit stream must have at least one transition from '0' to '1' or '1' to '0' every 16 bits during data transmission
- The bit rate matching between the transmitter and the receiver must be better than 6.5%

## 2.4.15 FREQUENCY ERROR INDICATOR (FEI)

This function provides information about the frequency error of the local oscillator (LO) compared with the carrier frequency of a modulated signal at the input of the receiver. When the FEI block is launched, the frequency error is measured and the signed result is loaded in FeiValue in RegFei, in 2's complement format. The time required for an FEI evaluation is four times the bit period.

To ensure a proper behavior of the FEI:

- The operation must be done during the reception of preamble
- The sum of the frequency offset and the 20 dB signal bandwidth must be lower than the base band filter bandwidth

The 20 dB bandwidth of the signal (double-side bandwidth) can be evaluated as shown in Equation 2-8.

### **EQUATION 2-8:**

$$BW_{20dB} \,=\, 2 \times \left(F_{DEV} + \frac{BR}{2}\right)$$

The frequency error, in Hz, can be calculated with the formula in Equation 2-9.

### **EQUATION 2-9:**

$$FEI = F_{STEP} \times FeiValue$$

### FIGURE 2-9: FEI PROCESS



## 2.4.16 AUTOMATIC FREQUENCY CORRECTION

The AFC is based on the FEI block, and therefore the same input signal and receiver setting conditions apply. When the AFC procedure is done, AfcValue is directly subtracted to the register that defines the frequency of operation of the chip, FRF. The AFC can be launched in the following cases:

- Each time the receiver is enabled, if AfcAutoOn = 1
- Upon user request, by setting bit AfcStart in RegAfcFei, if AfcAutoOn = 0

When the AFC is automatically triggered (AfcAutoOn = 1), the user has the option to:

- Clear the former AFC correction value, if AfcAutoClearOn = 1
- Start the AFC evaluation from the previously corrected frequency. This may be useful in systems in which the LO keeps on drifting in the same direction. Aging compensation is a good example.

The MRF39RA offers an alternate receiver bandwidth setting during the AFC phase to accommodate large LO drifts. If the user considers that the received signal may be out of the receiver bandwidth, a higher channel filter bandwidth can be programmed in RegAfcBw, at the expense of the receiver noise floor, which will impact upon sensitivity.

## 2.4.17 OPTIMIZED SETUP FOR LOW MODULATION INDEX SYSTEMS

For wide band systems, where AFC is usually not required (XTAL inaccuracies do not typically impact the sensitivity), it is recommended to offset the LO frequency of the receiver to avoid desensitization. This can be simply done by modifying Frf in RegFrfLsb. A good rule of thumb is to offset the receiver's LO by 10% of the expected transmitter frequency deviation.

For narrow band systems, it is recommended to perform AFC. The MRF39RA has a dedicated AFC, enabled when AfcLowBetaOn in RegAfcCtrl is set to '1'. A frequency offset, programmable through LowBetaAfcOffset in RegTestAfc, is added and is calculated as shown in Equation 2-10.

### **EQUATION 2-10:**

 $Offset = LowBetaAFCOffset \times 488 Hz$ 

The user should ensure that the programmed offset exceeds the DC canceler's cutoff frequency, set through DccFreqAfc in RegAfcBw.

# FIGURE 2-10: OPTIMIZED AFC (Afc LowBetaOn = 1)



As shown in Figure 2-10, a standard AFC sequence uses the result of the FEI to correct the LO frequency and align both local oscillators. When the optimized AFC is enabled (AfcLowBetaOn = 1), the receiver's LO is corrected by FeiValue + LowBetaAfcOffset.

When the optimized AFC routine is enabled, the receiver start-up time can be computed as shown in Equation 2-11 (see **Section 3.2.1** "**Receiver Start-up Time**").

### **EQUATION 2-11:**

 $TS\_RE\_AGC\&AFC \ (optimized \ AFC) = \\ = TANA + 4.TCF + 4.TDCC + 3.TRSSI + 2.TAFC + 2.TPLLAFC$ 

#### 2.4.18 TEMPERATURE SENSOR

When temperature is measured, the receiver ADC is used to digitize the sensor response. Most receiver blocks are disabled, and temperature measurement can only be triggered in Standby or Frequency Synthesizer modes.

The response of the temperature sensor is -1°C/Lsb. A CMOS temperature sensor is not accurate by nature; therefore, it should be calibrated at ambient temperature for precise temperature readings.



**FIGURE 2-11: TEMPERATURE SENSOR RESPONSE** 

It takes less than 100 microseconds for the MRF39RA evaluate the temperature (from setting TempMeasStart to '1' to TempMeasRunning Reset).

#### 2.4.19 TIME-OUT FUNCTION

The MRF39RA includes a time-out function, which allows it to automatically shut down the receiver after a receive sequence and therefore save energy.

- · Time-out interrupt is generated, TimeoutRxStart x 16 x Tbit, after switching to RX mode if RssiThreshold flag does not raise within this time frame.
- Time-out interrupt is generated. TimeoutRssiThresh x 16 x Tbit, after RssiThreshold flag has been raised.

This Time-out interrupt can be used to warn the companion processor to shut down the receiver and return to a lower power mode.

### 3.0 OPERATING MODES

### 3.1 Basic Modes

The circuit can be set in four different basic modes, which are described in Table 3-1.

By default, when switching from one mode to another, the sub-blocks are woken up according to a pre-defined and optimized sequence. Alternatively, these operating modes can be selected directly by disabling the automatic sequencer (SequencerOff in RegOpMode = 1).

TABLE 3-1: BASIC RECEIVER MODES

| ListenOn in RegOpMode | Mode in<br>RegOpMode | Selected mode | Enabled blocks                       |
|-----------------------|----------------------|---------------|--------------------------------------|
| 0                     | 0 0 0                | Sleep mode    | None                                 |
| 0                     | 0 0 1                | Stand-by mode | Top regulator and crystal oscillator |
| 0                     | 0 1 0                | FS mode       | Frequency synthesizer                |
| 0                     | 1 0 0                | Receive mode  | Frequency synthesizer and receiver   |
| 1                     | х                    | Listen mode   | See Section 3.3 "Listen Mode"        |

# 3.2 Automatic Sequencer and Wake-up Times

By default, when switching from one operating mode to another, the circuit takes care of the sequence of events in such a way that the transition timing is optimized. For example, when switching from Sleep mode to Receive mode, the MRF39RA first goes to Standby mode (XO started), then to Frequency Synthesizer mode, and finally, when the PLL has locked, to Receive mode.

The crystal oscillator wake-up time, TS\_OSC, is directly related to the time for the crystal oscillator to reach its steady state. This depends notably on the crystal characteristics.

The frequency synthesizer wake-up time, TS\_FS, is directly related to the time needed by the PLL to reach its steady state. The PLL\_LOCK signal, provided on an external pin, gives an indication of the lock status. It goes high when the PLL reaches its locking range.

Three specific cases can be highlighted:

- Receiver wake-up time from Sleep mode = TS\_OSC + TS\_FS + TS\_RE
- Receiver wake-up time from Sleep mode,
   AGC enabled = TS\_OSC + TS\_FS + TS\_RE\_AGC
- Receiver wake-up time from Sleep mode, AGC and AFC enabled = TS\_OSC + TS\_FS + TS\_RE\_AGC&AFC

These timings are detailed in Section 3.2.1 "Receiver Start-up Time".

In applications where the target average power consumption, or the target start-up time, do not require setting the MRF39RA in the lowest power modes (Sleep or Standby), the respective TS\_OSC and TS FS timings in the equations above can be omitted.

### 3.2.1 RECEIVER START-UP TIME

It is highly recommended to use the built-in sequencer of the MRF39RA to optimize the delays when setting the chip in Receive mode. It ensures the shortest start-up times, hence the lowest possible energy usage for battery operated systems.

The start-up times of the receiver can be calculated as shown in Figure 3-1 through Figure 3-3.

### FIGURE 3-1: Rx START-UP – NO AGC, NO AFC



### FIGURE 3-2: Rx START-UP - AGC, NO AFC



### FIGURE 3-3: Rx START-UP – AGC AND AFC



The different timings shown above are as follows:

- Group delay of the analog front end: Tana = 20 μs
- Channel filter's group delay in FSK mode: Tcf = 21/(4.RxBw)
- Channel filter's group delay in OOK mode:
   Tcf = 34/(4.RxBw)
- DC Cutoff's group delay: Tdcc = max(8, 2^(round(log2(8.RxBw.Tbit)+1))/(4.RxBw)
- PLL lock time after AFC adjustment: Tpllafc = 5/ PLLBW (PLLBW = 300 kHz)

- AFC sample time: Tafc = 4 x Tbit (also denoted TS\_AFC in the general specification)
- RSSI sample time: Trssi = 2 x int(4.RxBw.Tbit)/ (4.RxBw) (also known as TS\_RSSI)

**Note:** The above timings represent maximum settling times. Shorter settling times may be observed in real cases.

### 3.2.2 Rx Start Procedure

As described in the previous sections, the RxReady interrupt warns the uC that the receiver is ready.

- In Continuous mode with bit synchronizer, the receiver will start locking its bit synchronizer on a minimum or 12 bits of received preamble (see Section 2.4.14 "Bit Synchronizer" for details), before the reception of correct data or sync word (if enabled) can occur.
- In Continuous mode without bit synchronizer, valid data will be available on DIO2/DATA right after the RxReady interrupt.
- In Packet mode, the receiver will start locking its bit synchronizer on a minimum or 12 bits of received preamble (see Section 2.4.14 "Bit Synchronizer" for details), before the reception of correct data or sync word (if enabled) can occur.

# 3.2.3 Optimized Frequency Hopping Sequences

In a frequency hopping-like application, it is required to turn off the receiver when hopping from one channel to another, to optimize the hopping sequence:

Receiver hop from Ch A to Ch B:

- 1. MRF39RA is in Rx mode in Ch A
- Change the carrier frequency in the RegFrf registers
- 3. Program the MRF39RA in FS mode
- 4. Turn the receiver back to Rx mode
- Respect the Rx start procedure, described in Section 3.2.2 "Rx Start Procedure"

Note: The above sequence assumes that the sequencer is turned on (SequencerOff = 0 in RegOpMode).

### 3.3 Listen Mode

The circuit can be set to Listen mode, by setting ListenOn in RegOpMode to '1' while in Standby mode. In this mode, MRF39RA spends most of the time in Idle mode, during which only the RC oscillator runs. Periodically the receiver is woken up and listens for an RF signal. If a wanted signal is detected, the receiver is kept on and the data is demodulated.

Otherwise, if a wanted signal hasn't been detected after a pre-defined period of time, the receiver is disabled until the next time period.

This periodical Rx wake-up requirement is very common in low-power applications. On MRF39RA it is locally handled by the Listen mode block without using uC resources or energy.

The simplified timing diagram of this procedure is illustrated in Figure 3-4.

### FIGURE 3-4: LISTEN MODE SEQUENCE (NO WANTED SIGNAL IS RECEIVED)



### 3.3.1 Timings

The duration of the idle phase is given by  $t_{ListenIdle}$ . The time during which the receiver is on and is waiting for a signal is given by  $t_{ListenRx}$ .  $t_{ListenRx}$  includes the wake-up time of the receiver, described in Section 3.2.1 "Receiver Start-up Time". This duration can be programmed in the Configuration registers via the serial interface.

Both time periods  $t_{ListenRx}$  and  $t_{ListenIdle}$  (denoted  $t_{ListenX}$  in the text below) are fixed by two parameters from the Configuration register and are calculated as follows:

### **EQUATION 3-1:**

 $t_{ListenX} = ListenCoefX \cdot ListenResolX$ 

Where:

ListenResolX is the Rx or idle resolution and is independently programmable on three values (64  $\mu s$ , 4.1 ms or 262 ms), whereas ListenCoefX is an integer between 1 and 255. All parameters are located in RegListen registers.

The timing ranges are tabulated in Table 3-2 below.

TABLE 3-2: RANGE OF DURATIONS IN LISTEN MODE

| ListenResolX | Min duration<br>(ListenCoef = 1) | Max duration<br>(ListenCoef = 255) |
|--------------|----------------------------------|------------------------------------|
| 01           | 64 µs                            | 16 ms                              |
| 10           | 4.1 ms                           | 1.04s                              |
| 11           | 0.26s                            | 67s                                |

- **Note 1:** The accuracy of the typical timings given in Table 3-2 will depend in the RC oscillator calibration.
  - RC oscillator calibration is required and must be performed at power-up. See Section 3.3.5 "RC Timer Accuracy" for details.

### 3.3.2 Criteria

The criteria taken for detecting a wanted signal and hence deciding to maintain the receiver on is defined by ListenCriteria in RegListen1.

TABLE 3-3: SIGNAL ACCEPTANCE CRITERIA IN LISTEN MODE

| ListenCriteria | Input Signal Power ≥ RssiThreshold | SyncAddressMatch |
|----------------|------------------------------------|------------------|
| 0              | Required                           | Not Required     |
| 1              | Required                           | Required         |

### 3.3.3 End of Cycle Actions

The action taken after detection of a packet is defined by ListenEnd in RegListen3, as described in Table 3-4.

TABLE 3-4: END OF LISTEN CYCLE ACTION

| ListenEnd | Description                                                                                                                                                                    |  |  |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 00        | Chip stays in Rx mode. Listen mode stops and must be disabled.                                                                                                                 |  |  |
| 01        | Chip stays in Rx mode until <i>PayloadReady</i> or <i>Time-out</i> interrupt occurs. It then goes to the mode defined by <i>Mode</i> . Listen mode stops and must be disabled. |  |  |
| 10        | Chip stays in Rx mode until <i>PayloadReady</i> or <i>Time-out</i> interrupt occurs. Listen mode then resumes in Idle state. FIFO content is lost at next Rx wake-up.          |  |  |

Upon detection of a valid packet, the sequencing is altered, as shown in Figure 3-5 below.

FIGURE 3-5: LISTEN MODE SEQUENCE (WANTED SIGNAL IS RECEIVED)



Listen mode can be disabled by writing ListenOn to '0'.

### 3.3.4 Stopping Listen Mode

To abort Listen mode operation, the following procedure must be observed:

- Program RegOpMode with ListenOn = 0, ListenAbort = 1 and the desired setting for the Mode bits (Sleep, Stdby, FS, Rx or Tx mode) in a single SPI access
- Program RegOpMode with ListenOn = 0, ListenAbort = 0 and the desired setting for the Mode bits (Sleep, Stdby, FS, Rx or Tx mode) in a second SPI access

### 3.3.5 RC Timer Accuracy

All timings of the Listen mode rely on the accuracy of the internal low-power RC oscillator. This oscillator is automatically calibrated at the device power-up. This is a user-transparent process.

For applications enduring large temperature variations and for which the power supply is never removed, RC calibration can be performed on user request. RcCalStart in RegOsc1 can be used to trigger this calibration and the flag RcCalDone will automatically be set when the calibration is over.

### 3.4 Auto Modes

Automatic modes of packet handler can be enabled by configuring the related parameters in RegAutoModes.

The Intermediate mode of the chip is called IntermediateMode and the Enter and Exit conditions to/ from this Intermediate mode can be configured through the parameters EnterCondition and ExitCondition.

The Enter and Exit conditions cannot be used independently of each other (i.e., both should be enabled at the same time).

The initial and the final state is the one configured in the mode in RegOpMode. The initial and final states can be different by configuring the Modes register while the chip is in Intermediate mode. The pictorial description of the AutoModes is shown in Figure 3-6.

FIGURE 3-6: AUTO MODES OF PACKET HANDLER



Some typical examples of AutoModes usage are described below:

- Automatic reception (AutoRx):
  - Mode = Rx
  - IntermediateMode = Sleep
  - EnterCondition = CrcOk
  - ExitCondition = falling edge of FifoNotEmpty

### 4.0 DATA PROCESSING

### 4.1 Overview

### 4.1.1 BLOCK DIAGRAM

Figure 4-1 below illustrates the MRF39RA data processing circuit. Its role is to interface the data from the demodulator and the uC access points (SPI and DIO pins). It also controls all the Configuration registers.

The circuit contains several control blocks which are described in the following paragraphs.

FIGURE 4-1: MRF39RA DATA PROCESSING CONCEPTUAL VIEW



The MRF39RA implements several data operation modes, each with their own data path through the data processing section. Depending on the data operation mode selected, some control blocks are active while others remain disabled.

### 4.1.2 DATA OPERATION MODES

The MRF39RA has two different data operation modes selectable by the user:

- Continuous mode: each received bit is accessed in real time at the DIO2/DATA pin. This mode may be used if adequate external signal processing is available.
- Packet mode (recommended): user only retrieves payload bytes from the FIFO. The packet engine automatically removes the preamble, checks the sync word, performs AES decryption, checks the CRC and decodes DC-free schemes, if enabled. The uC processing overhead is hence significantly reduced compared to Continuous mode. Depending on the optional features activated (CRC, AES, etc) the maximum payload length is limited to FIFO size, 255 bytes or unlimited.

Each of these data operation modes is fully described in the following sections.

### 4.2 Control Block Description

### 4.2.1 SPI INTERFACE

The SPI interface gives access to the Configuration register via a synchronous full-duplex protocol corresponding to CPOL = 0 and CPHA = 0 in Motorola/ Freescale nomenclature. Only the slave side is implemented.

Three access modes to the registers are provided:

- Single Access: an address byte followed by a data byte is sent for a write access, whereas an address byte is sent and a read byte is received for the read access. The NSS pin goes low at the beginning of the frame and goes high after the data byte.
- Burst Access: the address byte is followed by several data bytes. The address is automatically incremented internally between each data byte. This mode is available for both read and write accesses. The NSS pin goes low at the beginning of the frame and stays low between each byte. It goes high only after the last byte transfer.
- FIFO access: if the address byte corresponds to the address of the FIFO, then succeeding data byte will address the FIFO. The address is not automatically incremented but is memorized and does not need to be sent between each data byte. The NSS pin goes low at the beginning of the frame and stays low between each byte. It goes high only after the last byte transfer.

Figure 4-2 below shows a typical SPI single access to a register.





MOSI is generated by the master on the falling edge of SCK and is sampled by the slave (i.e., this SPI interface) on the rising edge of SCK. MISO is generated by the slave on the falling edge of SCK.

A transfer always starts by the NSS pin going low. MISO is high-impedance when NSS is high.

The first byte is the address byte. It is made of:

- wnr bit, which is '1' for write access and '0' for read access
- · 7 bits of address, MSB first

The second byte is a data byte, either sent on MOSI by the master in case of a write access, or received by the master on MISO in case of a read access. The data byte is transmitted MSB first. Proceeding bytes may be sent on MOSI (for write access) or received on MISO (for read access) without rising NSS and re-sending the address. In FIFO mode, if the address was the FIFO address, then the bytes will be read at the FIFO address. In Burst mode, if the address was not the FIFO address, then it is automatically incremented at each new byte received.

The frame ends when NSS goes high. The next frame must start with an address byte. The Single Access mode is actually a special case of FIFO/Burst mode with only one data byte transferred.

During the write access, the byte transferred from the slave to the master on the MISO line is the value of the written register before the write operation.

### 4.2.2 FIFO

### 4.2.2.1 Overview and Shift Register (SR)

In Packet mode of operation, data that has been received is stored in a configurable FIFO (First In First Out) device. It is accessed via the SPI interface and provides several interrupts for transfer management.

The FIFO is 1-byte wide, hence it only performs byte (parallel) operations, whereas the demodulator functions serially. A Shift register is therefore employed to interface the two devices. In Rx the Shift register gets bit by bit data from the demodulator and writes them byte by byte to the FIFO. This is illustrated in Figure 4-3.

FIGURE 4-3: FIFO AND SHIFT REGISTER (SR)



Note: When switching to Sleep mode, the FIFO can only be used once the ModeReady flag is set (quasi immediate from all modes).

### 4.2.2.2 Size

The FIFO size is fixed to 66 bytes.

### 4.2.2.3 Interrupt Sources and Flags

- FifoNotEmpty: FifoNotEmpty interrupt source is low when byte 0 (i.e., whole FIFO, is empty).
   Otherwise it is high. Note that when retrieving data from the FIFO, FifoNotEmpty is updated on NSS falling edge (i.e., when FifoNotEmpty is updated to low state, the currently started read operation must be completed). In other words, FifoNotEmpty state must be checked after each read operation for a decision on the next one (FifoNotEmpty = 1: more bytes to read; FifoNotEmpty = 0: no more bytes to read).
- FifoFull: Fifofull interrupt source is high when the last FIFO byte (i.e., the whole FIFO, is full).
   Otherwise it is low.
- FifoOverrunFlag: FifoOverrunFlag is set when a new byte is written by the SR while the FIFO is already full. Data is lost and the flag should be cleared by writing a '1', note that the FIFO will also be cleared.
- FifoLevel: Threshold can be programmed by FifoThreshold in RegFifoThresh. Its behavior is illustrated in Figure 4-4.

FIGURE 4-4: FIFOLEVEL IRQ SOURCE BEHAVIOR



### 4.2.2.4 FIFO Clearing

Table 4-1 summarizes the status of the FIFO when switching between different modes.

TABLE 4-1: STATUS OF FIFO WHEN SWITCHING BETWEEN DIFFERENT MODES

| From        | То          | FIFO status | Comments                                                    |
|-------------|-------------|-------------|-------------------------------------------------------------|
| Stdby       | Sleep       | Not cleared |                                                             |
| Sleep       | Stdby       | Not cleared |                                                             |
| Stdby/Sleep | Rx          | Cleared     |                                                             |
| Rx          | Stdby/Sleep | Not cleared | To allow the user to read FIFO in Stdby/Sleep mode after Rx |

### 4.2.3 SYNC WORD RECOGNITION

### 4.2.3.1 Overview

Sync word recognition (also called pattern recognition) is activated by setting SyncOn in RegSyncConfig. The bit synchronizer must also be activated in Continuous mode (automatically done in Packet mode).

The block behaves like a Shift register; it continuously compares the incoming data with its internally programmed sync word and sets SyncAddressMatch when a match is detected. This is illustrated in Figure 4-5 below.

FIGURE 4-5: SYNC WORD RECOGNITION



During the comparison of the demodulated data, the first bit received is compared with bit 7 (MSB) of RegSyncValue1 and the last bit received is compared with bit 0 (LSB) of the last byte whose address is determined by the length of the sync word.

When the programmed sync word is detected, the user can assume that this incoming packet is for the node and can be processed accordingly.

SyncAddressMatch is cleared when leaving Rx or FIFO is emptied.

### 4.2.3.2 Configuration

- Size: sync word size can be set from 1 to 8 bytes (i.e., 8 to 64 bits) via SyncSize in RegSyncConfig
- Error tolerance: the number of errors tolerated in the sync word recognition can be set from 0 to 7 bits via SyncTol
- Value: the sync word value is configured in SyncValue(63:0)

**Note:** SyncValue choices containing 0x00 bytes are not allowed.

### 4.2.4 PACKET HANDLER

The packet handler is the block used in Packet mode. Its functionality is fully described in **Section 4.5** "Packet Mode".

### 4.2.5 CONTROL

The control block configures and controls the full chip behavior according to the settings programmed in the Configuration registers.

### 4.3 Digital I/O Pins Mapping

Six general purpose I/O pins are available on the MRF39RA. Their configuration in Continuous or Packet mode is controlled through RegDioMapping1 and RegDioMapping2.

# 4.3.1 DIO PINS MAPPING IN CONTINUOUS MODE

TABLE 4-2: DIO MAPPING, CONTINUOUS MODE

| Mode  | Diox<br>Mapping | DIO5      | DIO4        | DIO3     | DIO2 | DIO1        | DIO0        |
|-------|-----------------|-----------|-------------|----------|------|-------------|-------------|
| Sleep | 00              | _         | _           |          | _    | _           | _           |
|       | 01              | _         | _           | _        | _    | _           | _           |
|       | 10              | LowBat    | LowBat      | AutoMode | _    | LowBat      | LowBat      |
|       | 11              | ModeReady | _           | _        | _    | _           | ModeReady   |
| Stdby | 0.0             | ClkOut    | _           | _        | _    | _           | _           |
|       | 01              | _         | _           | _        | _    | _           | _           |
|       | 10              | LowBat    | LowBat      | AutoMode | _    | LowBat      | LowBat      |
|       | 11              | ModeReady | _           | _        | _    | _           | ModeReady   |
| FS    | 0.0             | ClkOut    | _           | _        | _    | _           | PllLock     |
|       | 01              | _         | _           | _        | _    | _           | _           |
|       | 10              | LowBat    | LowBat      | AutoMode | _    | LowBat      | LowBat      |
|       | 11              | ModeReady | PIILock     | _        | _    | PIILock     | ModeReady   |
| Rx    | 00              | ClkOut    | Timeout     | Rssi     | Data | Dclk        | SyncAddress |
|       | 01              | Rssi      | RxReady     | RxReady  | Data | RxReady     | Timeout     |
|       | 10              | LowBat    | SyncAddress | AutoMode | Data | LowBat      | Rssi        |
|       | 11              | ModeReady | PIILock     | Timeout  | Data | SyncAddress | ModeReady   |

# 4.3.2 DIO PINS MAPPING IN PACKET MODE

TABLE 4-3: DIO MAPPING, PACKET MODE

| Mode  | Diox<br>Mapping | DIO5      | DIO4    | DIO3        | DIO2         | DIO1         | DIO0         |
|-------|-----------------|-----------|---------|-------------|--------------|--------------|--------------|
| Sleep | 00              | _         | _       | FifoFull    | FifoNotEmpty | FifoLevel    | _            |
|       | 01              | _         | _       | _           | _            | FifoFull     | _            |
|       | 10              | LowBat    | LowBat  | LowBat      | LowBat       | FifoNotEmpty | LowBat       |
|       | 11              | ModeReady | _       | _           | AutoMode     | _            | _            |
| Stdby | 00              | ClkOut    | _       | FifoFull    | FifoNotEmpty | FifoLevel    | _            |
|       | 01              | _         | _       | _           | _            | FifoFull     | _            |
|       | 10              | LowBat    | LowBat  | LowBat      | LowBat       | FifoNotEmpty | LowBat       |
|       | 11              | ModeReady | _       | _           | AutoMode     | _            | _            |
| FS    | 00              | ClkOut    | _       | FifoFull    | FifoNotEmpty | FifoLevel    | _            |
|       | 01              | _         | _       | _           | _            | FifoFull     | _            |
|       | 10              | LowBat    | LowBat  | LowBat      | LowBat       | FifoNotEmpty | LowBat       |
|       | 11              | ModeReady | PIILock | PIILock     | AutoMode     | PIILock      | PIILock      |
| Rx    | 00              | ClkOut    | Timeout | FifoFull    | FifoNotEmpty | FifoLevel    | CrcOk        |
|       | 01              | Data      | Rssi    | Rssi        | Data         | FifoFull     | PayloadReady |
|       | 10              | LowBat    | RxReady | SyncAddress | LowBat       | FifoNotEmpty | SyncAddress  |
|       | 11              | ModeReady | PIILock | PllLock     | AutoMode     | Timeout      | Rssi         |

Note: Received data is only shown on the data signal between RxReady and PayloadReady's rising edges.

### 4.4 Continuous Mode

### 4.4.1 GENERAL DESCRIPTION

As illustrated in Figure 4-6, in Continuous mode the NRZ data from the demodulator is directly accessed by the uC on the DIO2/DATA pin. The FIFO and packet handler are thus inactive.

FIGURE 4-6: CONTINUOUS MODE CONCEPTUAL VIEW



### 4.4.2 RX PROCESSING

If the bit synchronizer is disabled, the raw demodulator output is made directly available on DATA pin and no DCLK signal is provided.

Conversely, if the bit synchronizer is enabled, synchronous cleaned data and clock are made available on DIO2/DATA and DIO1/DCLK pins, respectively. DATA is sampled on the rising edge of DCLK and updated on the falling edge as illustrated in Figure 4-7.

FIGURE 4-7: RX PROCESSING IN CONTINUOUS MODE



Note: In Continuous mode it is always recommended to enable the bit synchronizer to clean the DATA signal even if the DCLK signal is not used by the uC (bit synchronizer is automatically enabled in Packet mode).

#### 4.5 **Packet Mode**

#### 4.5.1 **GENERAL DESCRIPTION**

In Packet mode the NRZ data from the demodulator is not directly accessed by the uC but stored in the FIFO and accessed via the SPI interface.

In addition, the MRF39RA packet handler performs several packet-oriented tasks such as preamble and sync word check, CRC check, de-whitening of data, Manchester decoding, address filtering, AES decryption, etc. This simplifies software and reduces uC overhead by performing these repetitive tasks within the RF chip itself.

Another important feature is ability to empty the FIFO in Sleep/Stdby mode, ensuring optimum power consumption and adding more flexibility for the software.

DIO0 DIO1 DIO2 CONTROL DIO3 DIO4 DIO5 NSS Data Rx **PACKET SYNC FIFO** SCK SPI HANDLER RECOG. (+SR) MOSI MISO

FIGURE 4-8: PACKET MODE CONCEPTUAL VIEW

The bit synchronizer is automatically Note: enabled in Packet mode.

### 4.5.2 PACKET FORMAT

Optional 2-Byte CRC Checksum

### 4.5.2.1 Fixed Length Packet Format

Fixed length packet format is selected when bit PacketFormat is set to '0' and PayloadLength is set to any value greater than '0'.

In applications where the packet length is fixed in advance, this mode of operation may be of interest to minimize RF overhead (no length byte field is required). All nodes should be programmed with the same packet length value.

The length of the payload is limited to 255 bytes if AES is not enabled; otherwise, the message is limited to 64 bytes (i.e., maximum 65 bytes payload if Address byte is enabled).

The length programmed in PayloadLength relates only to the payload which includes the message and the optional address byte. In this mode, the payload must contain at least one byte (i.e., address or message byte).

An illustration of a fixed length packet is shown below. It contains the following fields:

- Preamble (1010...)
- Sync Word (Network ID)
- · Optional Address Byte (Node ID)
- · Message Data

FIGURE 4-9: FIXED LENGTH PACKET FORMAT



### 4.5.2.2 Variable Length Packet Format

Variable length packet format is selected when bit PacketFormat is set to '1'.

This mode is useful in applications where the length of the packet is not known in advance and can vary over time. It is then necessary for the transmitter to send the length information together with each packet in order for the receiver to operate properly.

In this mode, the length of the payload indicated by the length byte is given by the first byte of the FIFO and is limited to 255 bytes if AES is not enabled; otherwise, the message is limited to 64 bytes (i.e., max 66 bytes payload, if address byte is enabled). Note that the length byte itself is not included in its calculation. In this mode, the payload must contain at least two bytes (i.e., length + address or message byte).

An illustration of a variable length packet is shown below. It contains the following fields:

- Preamble (1010...)
- Sync Word (Network ID)
- · Length Byte
- Optional Address Byte (Node ID)
- · Message Data
- · Optional 2-Byte CRC Checksum

### FIGURE 4-10: VARIABLE LENGTH PACKET FORMAT



### 4.5.2.3 Unlimited Length Packet Format

Unlimited length packet format is selected when bit PacketFormat is set to '0' and PayloadLength is set to '0'.

The user can then receive packets of arbitrary length and PayloadLength register is not used in Rx modes for counting the length of the bytes received.

The data processing features such as address filtering, Manchester decoding and data de-whitening are not available if the sync pattern length is set to zero (SyncOn = '0'). The CRC detection is also not supported in this mode of the packet handler. Interrupts such as CrcOk and PayloadReady are not available either.

An unlimited length packet shown in Figure 4-11 is made up of the following fields:

- Preamble (1010...).
- · Sync Word (Network ID).
- · Optional Address Byte (Node ID).
- · Message Data

### FIGURE 4-11: UNLIMITED LENGTH PACKET FORMAT



### 4.5.3 PROCESSING (WITHOUT AES)

In Rx mode the packet handler extracts the user payload to the FIFO by performing the following operations:

- · Receiving the preamble and stripping it off
- · Detecting the sync word and stripping it off
- · Optional DC-free decoding of data
- · Optionally checking the address byte
- Optionally checking CRC and reflecting the result on CrcOk

Only the payload (including optional address and length fields) is made available in the FIFO.

When the Rx mode is enabled the demodulator receives the preamble followed by the detection of sync word. If fixed length packet format is enabled, then the number of bytes received as the payload is given by the PayloadLength parameter.

In Variable Length mode, the first byte received after the sync word is interpreted as the length of the received packet. The internal length counter is initialized to this received length. The PayloadLength register is set to a value which is greater than the maximum expected length of the received packet. If the received length is greater than the maximum length stored in PayloadLength register, the packet is discarded; otherwise, the complete packet is received.

If the address check is enabled, then the second byte received in case of variable length and first byte in case of fixed length is the address byte. If the address matches the one in the NodeAddress field, reception of the data continues; otherwise, it is stopped. The CRC check is performed if CrcOn = 1 and the result is available in CrcOk, indicating that the CRC was successful. An interrupt (PayloadReady) is also generated on DIO0 as soon as the payload is available in the FIFO. The payload available in the FIFO can also be read in Sleep/Standby mode.

If the CRC fails, the PayloadReady interrupt is not generated and the FIFO is cleared. This function can be overridden by setting CrcAutoClearOff = 1, thus forcing the availability of the PayloadReady interrupt and the payload in the FIFO, even if the CRC fails.

#### 4.5.4 AES

AES is the symmetric-key block cipher that provides the cryptographic capabilities to the receiver. The system proposed can work with 128-bit long fixed keys. The fixed key is stored in a 16-byte write-only user Configuration register, which retains its value in Sleep mode.

As shown in Figure 4-9 and Figure 4-10 above, the message part of the packet can be decrypted with the 128-cipher key stored in the Configuration registers.

#### 4.5.4.1 Processing

The data received is stored in the FIFO. The address, CRC interrupts are generated as usual because these parameters were not encrypted.

As soon as the complete packet has been received, the data is read from the FIFO, decrypted and written back to FIFO. The PayloadReady interrupt is issued once the decrypted data is ready for reading in the FIFO via the SPI interface.

The AES decryption cannot be used on the fly (i.e., while receiving data). Thus, when AES decryption is enabled, the FIFO acts as a simple buffer. The decryption is initiated only when the complete packet has been received in the buffer.

The decryption process takes approximately 7.0  $\mu$ s per 16-byte block. Thus, for a maximum of four blocks (i.e., 64 bytes) it can take up to 28  $\mu$ s for completing the cryptographic operations.

The receiver sees the AES decryption time as a sequential delay before the PayloadReady interrupt is available.

In Fixed Length mode, the message part of the payload that can be decrypted can be 64-byte long. If the address filtering is enabled, the length of the payload should be at maximum 65 bytes in this case.

In Variable Length mode the maximum message size that can be decrypted is also 64 bytes whether address comparison is enabled or not. Thus, including length byte, the length of the payload is either 65 or 66 bytes maximum (the latter, when address comparison is enabled).

Crc check being performed on encrypted data, CrcOk interrupt will occur "decryption time" before *PayloadReady* interrupt.

#### 4.5.5 HANDLING LARGE PACKETS

When Payload length exceeds FIFO size (66 bytes) whether in fixed, variable or unlimited length packet format, in addition to PayloadReady or CrcOk in Rx, the FIFO interrupts/flags can be used as described below:

FIFO must be unfilled on the fly during Rx to prevent FIFO overrun.

- Start reading bytes from the FIFO when FifoNotEmpty or FifoThreshold becomes set.
- Suspend reading from the FIFO if FifoNotEmpty clears before all bytes of the message have been read
- 3. Continue to step 1 until PayloadReady
- Read all remaining bytes from the FIFO either in Rx or Sleep/Standby mode

**Note:** AES decryption is not feasible on large packets, since all Payload bytes need to be in the FIFO at the same time to perform decryption.

### 4.5.6 PACKET FILTERING

MRF39RA's packet handler offers several mechanisms for packet filtering, ensuring that only useful packets are made available to the uC, reducing significantly system power consumption and software complexity.

### 4.5.6.1 Sync Word-Based

Sync word filtering/recognition is used for identifying the start of the payload and also for network identification. As previously described, the sync word recognition block is configured (size, error tolerance, value) in RegSyncValue registers. This information is used to filter packets in Rx.

Every received packet which does not start with this locally configured sync word is automatically discarded and no interrupt is generated.

When the sync word is detected, payload reception automatically starts and SyncAddressMatch is asserted.

**Note:** Sync word values containing 0x00 byte(s) are forbidden.

#### 4.5.6.2 Address-Based

Address filtering can be enabled via the AddressFiltering bits. It adds another level of filtering above sync word (i.e., sync must match first), typically useful in a multi-node networks where a network ID is shared between all nodes (sync word) and each node has its own ID (address).

Two address-based filtering options are available:

- AddressFiltering = 01: Received address field is compared with internal register NodeAddress. If they match, then the packet is accepted and processed, otherwise it is discarded.
- AddressFiltering = 10: Received address field is compared with internal registers NodeAddress and BroadcastAddress. If either is a match, the received packet is accepted and processed, otherwise it is discarded. This additional check with a constant is useful for implementing broadcast in a multi-node networks.

As address filtering requires a sync word match, both features share the same interrupt flag SyncAddressMatch.

Please note that the received address byte, as part of the payload, is not stripped off the packet and is made available in the FIFO.

#### 4.5.6.3 Length-Based

In variable length Packet mode, PayloadLength must be programmed with the maximum payload length permitted. If received length byte is smaller than this maximum, then the packet is accepted and processed, otherwise it is discarded.

Please note that the received length byte, as part of the payload, is not stripped off the packet and is made available in the FIFO.

To disable this function the user should set the value of the PayloadLength to 255.

### 4.5.6.4 CRC-Based

The CRC check is enabled by setting bit CrcOn in RegPacketConfig1. It is used for checking the integrity of the message. The checksum is calculated on the received payload and compared with the two checksum bytes received. The result of the comparison is stored in bit CrcOk.

By default, if the CRC check fails then the FIFO is automatically cleared and no interrupt is generated. This filtering function can be disabled via CrcAutoClearOff bit and in this case, even if CRC fails, the FIFO is not cleared and only PayloadReady interrupt goes high. Please note that in both cases, the two CRC checksum bytes are stripped off by the packet handler and only the payload is made available in the FIFO.

The CRC is based on the CCITT polynomial (see Figure 4-12). This implementation also detects errors due to leading and trailing zeros.

### FIGURE 4-12: CRC IMPLEMENTATION



# 4.5.7 DC-FREE DATA MECHANISMS

The received payload can be de-whitened or Manchester-decoded automatically in the MRF39RA packet handler.

**Note:** Only one of the two methods should be enabled at a time.

### 4.5.7.1 Manchester Decoding

Manchester decoding is enabled if DcFree = 01 and it can only be used in Packet mode.

The Manchester data is decoded to NRZ code by decoding '10' as '1' and '01' as '0'.

In this case, the maximum chip rate is the maximum bit rate given in the specifications section, and the actual bit rate is half the chip rate.

Manchester decoding is only applied to the payload and CRC checksum while preamble and sync word are kept NRZ. However, the chip rate from preamble to CRC is the same and defined by BitRate in RegBitRate (Chip Rate = Bit Rate NRZ = 2 x Bit Rate Manchester).

Manchester decoding is thus made transparent for the user, who still retrieves NRZ data from the FIFO.

FIGURE 4-13: MANCHESTER DECODING

|                                 |       | 1/BR | S | ync |   |   |   |   |   | 1/BR |   | Pa | yload | k |   |   |   |  |
|---------------------------------|-------|------|---|-----|---|---|---|---|---|------|---|----|-------|---|---|---|---|--|
| RF chips @ BR                   | <br>1 | 1    | 1 | 0   | 1 | 0 | 0 | 1 | 0 | 0    | 1 | 0  | 1     | 1 | 0 | 1 | 0 |  |
| Jser/NRZ bits<br>Manchester OFF | <br>1 | 1    | 1 | 0   | 1 | 0 | 0 | 1 | 0 | 0    | 1 | 0  | 1     | 1 | 0 | 1 | 0 |  |
| ser/NRZ bits<br>lanchester ON   | <br>1 | 1    | 1 | 0   | 1 | 0 | 0 |   | L | C    | ) |    | 0     | 1 | L | : | 1 |  |

# 4.5.7.2 Data De-Whitening

Another technique called whitening or scrambling is widely used for randomizing the user data before radio transmission. The data is whitened using a random sequence on the Tx side and de-whitened on the Rx side using the same sequence. Compared to the Manchester technique it has the advantage of keeping the NRZ data rate (i.e., the actual bit rate is not halved).

The de-whitening process is enabled if DcFree = 10. The data, including payload and 2-byte CRC checksum, is de-whitened by XORing it with a random sequence generated in a 9-bit LFSR, shown in Figure 4-14.

Payload de-whitening is thus made transparent for the user, who still retrieves NRZ data from the FIFO.

FIGURE 4-14: DATA WHITENING



# 5.0 CONFIGURATION AND STATUS REGISTERS

# 5.1 General Description

TABLE 5-1: REGISTERS SUMMARY

| Address |                | Reset      | Default       | Decerintian                                        |
|---------|----------------|------------|---------------|----------------------------------------------------|
| Address | Register Name  | (Built-in) | (Recommended) | Description                                        |
| 0x00    | RegFifo        |            | 0x00          | FIFO read/write access                             |
| 0x01    | RegOpMode      |            | 0x04          | Operating modes of the receiver                    |
| 0x02    | RegDataModul   |            | 0x00          | Data Operation mode and modulation settings        |
| 0x03    | RegBitrateMsb  |            | 0x1A          | Bit rate setting, Most Significant bits            |
| 0x04    | RegBitrateLsb  |            | 0x0B          | Bit rate setting, Least Significant bits           |
| 0x05    | Reserved05     |            | 0x00          | _                                                  |
| 0x06    | Reserved06     |            | 0x52          | _                                                  |
| 0x07    | RegFrfMsb      |            | 0xE4          | RF carrier frequency, Most Significant bits        |
| 80x0    | RegFrfMid      |            | 0xC0          | RF carrier frequency, Intermediate bits            |
| 0x09    | RegFrfLsb      |            | 0x00          | RF carrier frequency, Least Significant bits       |
| 0x0A    | RegOsc1        |            | 0x41          | RC oscillators settings                            |
| 0x0B    | RegAfcCtrl     |            | 0x00          | AFC control in low modulation index situations     |
| 0x0C    | RegLowBat      |            | 0x02          | Low battery indicator settings                     |
| 0x0D    | RegListen1     |            | 0x92          | Listen mode settings                               |
| 0x0E    | RegListen2     |            | 0xF5          | Listen mode Idle duration                          |
| 0x0F    | RegListen3     |            | 0x20          | Listen mode Rx duration                            |
| 0x10    | RegVersion     | 0x23       |               | Microchip ID relating the silicon revision         |
| 0x11    | Reserved11     | 0x9F       |               | _                                                  |
| 0x12    | Reserved12     | 0x09       |               | _                                                  |
| 0x13    | Reserved13     |            | 0x1A          | _                                                  |
| 0x14    | Reserved14     |            | 0x40          | _                                                  |
| 0x15    | Reserved15     |            | 0xB0          | _                                                  |
| 0x16    | Reserved16     |            | 0x7B          | _                                                  |
| 0x17    | Reserved17     |            | 0x9B          | _                                                  |
| 0x18    | RegLna         | 0x08       | 0x88          | LNA settings                                       |
| 0x19    | RegRxBw        | 0x86       | 0x55          | Channel filter BW control                          |
| 0x1A    | RegAfcBw       | 0x8A       | 0x8B          | Channel filter BW control during the AFC routine   |
| 0x1B    | RegOokPeak     |            | 0x40          | OOK demodulator selection and control in Peak mode |
| 0x1C    | RegOokAvg      |            | 0x80          | Average threshold control of the OOK demodulator   |
| 0x1D    | RegOokFix      |            | 0x06          | Fixed threshold control of the OOK demodulator     |
| 0x1E    | RegAfcFei      |            | 0x10          | AFC and FEI control and status                     |
| 0x1F    | RegAfcMsb      |            | 0x00          | MSB of the frequency correction of the AFC         |
| 0x20    | RegAfcLsb      |            | 0x00          | LSB of the frequency correction of the AFC         |
| 0x21    | RegFeiMsb      |            | 0x00          | MSB of the calculated frequency error              |
| 0x22    | RegFeiLsb      |            | 0x00          | LSB of the calculated frequency error              |
| 0x23    | RegRssiConfig  |            | 0x02          | RSSI-related settings                              |
| 0x24    | RegRssiValue   |            | 0xFF          | RSSI value in dBm                                  |
| 0x25    | RegDioMapping1 |            | 0x00          | Mapping of pins DIO0 to DIO3                       |
| 0x26    | RegDioMapping2 | 0x05       | 0x07          | Mapping of pins DIO4 and DIO5, ClkOut frequency    |

TABLE 5-1: REGISTERS SUMMARY (CONTINUED)

| Address           | Register Name    | Reset<br>(Built-in) | Default<br>(Recommended) | Description                                                  |
|-------------------|------------------|---------------------|--------------------------|--------------------------------------------------------------|
| 0x27              | ReglrqFlags1     |                     | 0x80                     | Status register: PLL lock state, time out, RSSI > Threshold  |
| 0x28              | ReglrqFlags2     | 0x00                |                          | Status register: FIFO handling flags, low battery detection  |
| 0x29              | RegRssiThresh    | 0xFF                | 0xE4                     | RSSI threshold control                                       |
| 0x2A              | RegRxTimeout1    |                     | 0x00                     | Time-out duration between Rx request and RSSI detection      |
| 0x2B              | RegRxTimeout2    |                     | 0x00                     | Time-out duration between RSSI detection and<br>PayloadReady |
| 0x2C              | Reserved2C       |                     | 0x00                     | -                                                            |
| 0x2D              | Reserved2D       |                     | 0x03                     | -                                                            |
| 0x2E              | RegSyncConfig    |                     | 0x98                     | Sync word recognition control                                |
| 0x2F<br>-<br>0x36 | RegSyncValue1-8  | 0x00                | 0x01                     | Sync word bytes, 1 through 8                                 |
| 0x37              | RegPacketConfig1 |                     | 0x10                     | Packet mode settings                                         |
| 0x38              | RegPayloadLength |                     | 0x40                     | Payload length setting                                       |
| 0x39              | RegNodeAdrs      |                     | 0x00                     | Node address                                                 |
| 0x3A              | RegBroadcastAdrs |                     | 0x00                     | Broadcast address                                            |
| 0x3B              | RegAutoModes     |                     | 0x00                     | Auto modes settings                                          |
| 0x3C              | RegFifoThresh    | 0x0F                | 0x8F                     | FIFO threshold                                               |
| 0x3D              | RegPacketConfig2 |                     | 0x02                     | Packet mode settings                                         |
| 0x3E<br>-<br>0x4D | RegAesKey1-16    |                     | 0x00                     | 16 bytes of the cypher key                                   |
| 0x4E              | RegTemp1         |                     | 0x01                     | Temperature Sensor control                                   |
| 0x4F              | RegTemp2         |                     | 0x00                     | Temperature readout                                          |
| 0x58              | RegTestLna       |                     | 0x1B                     | Sensitivity boost                                            |
| 0x59              | RegTestTcxo      |                     | 0x09                     | XTAL or TCXO input selection                                 |
| 0x5F              | RegTestIIBw      |                     | 0x08                     | PLL bandwidth setting                                        |
| 0x6F              | RegTestDagc      | 0x00                | 0x30                     | Fading margin Improvement                                    |
| 0x71              | RegTestAfc       |                     | 0x00                     | AFC offset for low modulation index AFC                      |
| 0x50 +            | RegTest          |                     |                          | Internal test registers                                      |

- **Note 1:** Reset values are automatically refreshed in the chip at Power-on Reset.
  - **2:** Default values are the Microchip recommended register values, optimizing the device operation.
  - 3: Registers for which the default value differs from the Reset value are denoted by an \* in the tables of Section 5.0 "Configuration and Status Registers".

# 5.2 Common Configuration Registers

TABLE 5-2: COMMON CONFIGURATION REGISTERS

| Name                 |      | ION CONFIGUR   |      | Default |                                                                                                                                                                                                                                      |
|----------------------|------|----------------|------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (Address)            | Bits | Variable Name  | Mode | Value   | Description                                                                                                                                                                                                                          |
| RegFifo (0x00)       | 7-0  | Fifo           | rw   | 0x00    | FIFO data output                                                                                                                                                                                                                     |
| RegOpMode<br>(0x01)  | 7    | SequencerOff   | rw   | 0       | Controls the automatic sequencer (see Section 3.2  "Automatic Sequencer and Wake-up Times"):  0 → Operating mode as selected with Mode bits in RegOpMode is automatically reached with the Sequencer  1 → Mode is forced by the user |
|                      | 6    | ListenOn       | rw   | 0       | Enables Listen mode; it should be enabled while in Standby mode:  0 → OFF (see Section 3.3 "Listen Mode")  1 → ON                                                                                                                    |
|                      | 5    | ListenAbort    | w    | 0       | Aborts Listen mode when set together with  ListenOn = 0 (see Section 3.3.4 "Stopping Listen  Mode")  Always reads '0'                                                                                                                |
|                      | 4-2  | Mode           | rw   | 001     | Receiver's operating modes:  000 → Sleep mode (SLEEP)  001 → Standby mode (STDBY)  010 → Frequency Synthesizer mode (FS)  100 → Receiver mode (RX)  Others → Reserved  Reads the value corresponding to the current chip mode        |
|                      | 1-0  | 1-0 —          |      | 00      | Unused                                                                                                                                                                                                                               |
| RegDataModule        | 7    | _              | r    | 0       | Unused                                                                                                                                                                                                                               |
| (0x02)               | 6-5  | DataMode       | rw   | 00      | Data Processing mode:  00 → Packet mode  01 → Reserved  10 → Continuous mode with bit synchronizer  11 → Continuous mode without bit synchronizer                                                                                    |
|                      | 4-3  | ModulationType | rw   | 00      | Modulation scheme:  00 → FSK  01 → OOK  10 - 11 → Reserved                                                                                                                                                                           |
|                      | 2-0  | _              | r    | 000     | Unused                                                                                                                                                                                                                               |
| RegBitrateMsb (0x03) | 7-0  | BitRate(15:8)  | rw   | 0X1A    | MSB of bit rate (chip rate when Manchester encoding is enabled)                                                                                                                                                                      |
| RegBitrateLsb (0x04) | 7-0  | BitRate(7:0)   | rw   | 0X0B    | LSB of bit rate (chip rate if Manchester encoding is enabled) $BitRate = \frac{FXOSC}{BitRate(15,0)}$ Default value: 4.8 kbps                                                                                                        |
| Reserved05<br>(0x05) | 7-0  | _              | r    | 0X00    | Unused                                                                                                                                                                                                                               |
| Reserved06<br>(0x06) | 7-0  | _              | r    | 0X52    | Unused                                                                                                                                                                                                                               |

TABLE 5-2: COMMON CONFIGURATION REGISTERS (CONTINUED)

| Name<br>(Address)   | Bits | Variable Name | Mode | Default<br>Value | Description                                                                                                                                                                                     |  |
|---------------------|------|---------------|------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| RegFrfMsb<br>(0x07) | 7-0  | Frf(23:16)    | rw   | 0XE4             | MSB of the RF local oscillator                                                                                                                                                                  |  |
| RegFrfMid<br>(0x08) | 7-0  | Frf(15:8)     | rw   | 0XC0             | Middle byte of the RF local oscillator                                                                                                                                                          |  |
| RegFrfLsb<br>(0x09) | 7-0  | Frf(7:0)      | rw   | 0x00             | LSB of the RF local oscillator $Frf = Fstep \times Frf(23;0)$                                                                                                                                   |  |
| RegOsc1<br>(0x0A)   | 7    | RcCalStart    | w    | 0                | Default value: Frf = 915 MHz (32 MHz XO)  Triggers the calibration of the RC oscillator when set.  Always reads '0'. RC calibration must be triggered in Standby mode.                          |  |
|                     | 6    | 6 RcCalDone   |      | 1                | <ul> <li>0 → RC calibration in progress</li> <li>1 → RC calibration is over</li> </ul>                                                                                                          |  |
|                     | 5-0  | _             | r    | 000001           | Unused                                                                                                                                                                                          |  |
| RegAfcCtrl          | 7-6  | _             | r    | 00               | Unused                                                                                                                                                                                          |  |
| (0x0B)              | 5    | AfcLowBetaOn  | rw   | 0                | Improved AFC routine for signals with modulation index lower than 2 (see Section 2.4.17 "Optimized Setup for Low Modulation Index Systems")  0 → Standard AFC routine  1 → Improved AFC routine |  |
|                     | 4-0  | _             | r    | 00000            | Unused                                                                                                                                                                                          |  |
| RegLowBat           | 7-5  | _             | r    | 000              | Unused                                                                                                                                                                                          |  |
| (0x0C)              | 4    | LowBatMonitor | rw   | _                | Real-time (not latched) output of the low battery detector, when enabled.                                                                                                                       |  |
|                     | 3    | LowBatOn      | rw   | 0                | Low Battery detector enable signal  0 → LowBat OFF  1 → LowBat ON                                                                                                                               |  |
|                     | 2-0  | LowBatTrim    | rw   | 010              | Trimming of the <i>LowBat</i> threshold:  000 → 1.695V  010 → 1.835V  100 → 1.976V  110 → 2.116V  001 → 1.764V  011 → 1.905V  101 → 2.045V  111 → 2.185V                                        |  |

TABLE 5-2: COMMON CONFIGURATION REGISTERS (CONTINUED)

| Name<br>(Address)    | Bits           | Variable Name   | Mode | Default<br>Value                                                                                                                                               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------------|----------------|-----------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RegListen1 (0x0D)    | 7-6            | ListenResolldle | rw   | 10                                                                                                                                                             | Resolution of Listen modes timings (calibrated RC osc):  0101 → 64 µs  1010 → 4.1 ms  1111 → 262 ms  Others → Reserved                                                                                                                                                                                                                                                                                                                                                                                                      |
|                      | 5-4            | ListenResolRx   | rw   | 01                                                                                                                                                             | Resolution of Listen mode Rx time (calibrated RC osc): $00 \rightarrow \text{Reserved}$ $01 \rightarrow 64 \ \mu\text{s}$ $10 \rightarrow 4.1 \ \text{ms}$ $11 \rightarrow 262 \ \text{ms}$                                                                                                                                                                                                                                                                                                                                 |
|                      | ListenCriteria | rw              | 0    | Criteria for packet acceptance in Listen mode:  0 → Signal strength is above RssiThreshold  1 → Signal strength is above RssiThreshold and SyncAddress matched |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                      | 2-1            | ListenEnd       | rw   | 01                                                                                                                                                             | Action taken after acceptance of a packet in Listen mode:  00 → Chip stays in Rx mode. Listen mode stops and must be disabled (see Section 3.3 "Listen Mode").  01 → Chip stays in Rx mode until PayloadReady or Time-out interrupt occurs. It then goes to the mode defined by Mode. Listen mode stops and must be disabled (see Section 3.3 "Listen Mode").  10 → Chip stays in Rx mode until PayloadReady or Time-out interrupt occurs. Listen mode then resumes in idle state. FIFO content is lost at next Rx wake-up. |
|                      | 0              | _               | r    | 0                                                                                                                                                              | Unused                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| RegListen2<br>(0x0E) | 7-0            | ListenCoefldle  | rw   | 0xf5                                                                                                                                                           | Duration of the Idle phase in Listen mode. $t_{ListenIdle} = ListenCoefIdle \bullet ListenResolIdle$                                                                                                                                                                                                                                                                                                                                                                                                                        |
| RegListen3<br>(0x0F) | 7-0            | ListenCoefRx    | rw   | 0x20                                                                                                                                                           | Duration of the Rx phase in Listen mode (start-up time included, see <b>Section 3.2.1</b> "Receiver Start-up Time") $t_{ListenRx} = ListenCoefRx \bullet ListenResolRx$                                                                                                                                                                                                                                                                                                                                                     |
| RegVersion (0x10)    | 7-0            | Version         | r    | 0x23                                                                                                                                                           | Version code of the chip. Bits 7-4 give the full revision number. Bits 3-0 give the metal mask revision number.                                                                                                                                                                                                                                                                                                                                                                                                             |

# 5.3 Receiver Registers

TABLE 5-3: RECEIVER REGISTERS

| Name<br>(Address)    | Bits | Variable Name  | Mode | Default<br>Value | Description                                                                                                                                                                                                                                                             |
|----------------------|------|----------------|------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved14<br>(0x14) | 7-0  | _              | r    | 0x40             | Unused                                                                                                                                                                                                                                                                  |
| Reserved15<br>(0x15) | 7-0  | _              | r    | 0xB0             | Unused                                                                                                                                                                                                                                                                  |
| Reserved16 (0x16)    | 7-0  | _              | r    | 0x7B             | Unused                                                                                                                                                                                                                                                                  |
| Reserved17<br>(0x17) | 7-0  | _              | r    | 0x9B             | Unused                                                                                                                                                                                                                                                                  |
| RegLna<br>(0x18)     | 7    | LnaZin         | rw   | 1*               | LNA's input impedance<br>0 → 50 ohms<br>1 → 200 ohms                                                                                                                                                                                                                    |
|                      | 6    | _              | r    | 0                | Unused                                                                                                                                                                                                                                                                  |
|                      | 5-3  | LnaCurrentGain | r    | 001              | Current LNA gain set either manually or by the AGC                                                                                                                                                                                                                      |
|                      | 2-0  | LnaGainSelect  | rw   | 000              | LNA gain setting:  000 → Gain set by the internal AGC loop  001 → G1 = Highest gain  010 → G2 = Highest gain – 6 dB  011 → G3 = Highest gain – 12 dB  100 → G4 = Highest gain – 24 dB  101 → G5 = Highest gain – 36 dB  110 → G6 = Highest gain – 48 dB  111 → Reserved |
| RegRxBw<br>(0x19)    | 7-5  | DccFreq        | rw   | 010*             | Cut-off frequency of the DC offset canceler (DCC): $fc = \frac{4 \times RxBw}{2\pi \times 2^{DccFreq+2}}$ ~4% of the RxBw by default                                                                                                                                    |
|                      | 4-3  | RxBwMant       | rw   | 10               | Channel filter bandwidth control:  00 → RxBwMant = 16  10 → RxBwMant = 24  01 → RxBwMant = 20  11 → Reserved                                                                                                                                                            |
|                      | 2-0  | RxBwExp        | rw   | 101              | Channel filter bandwidth control: $FSK \text{ mode:}$ $RxBw = \frac{FXOSC}{RxBwMant \times 2^{RxBwExp+2}}$ OOK mode: $RxBw = \frac{FXOSC}{RxBwMant \times 2^{RxBwExp+3}}$ See Table 2-3 for tabulated values.                                                           |

TABLE 5-3: RECEIVER REGISTERS (CONTINUED)

| Name<br>(Address)    | Bits | Variable Name        | Mode | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------|------|----------------------|------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RegAfcBw             | 7-5  | DccFreqAfc           | rw   | 100              | DccFreq parameter used during the AFC                                                                                                                                                                                                                                                                                                                                         |
| (0x1A)               | 4-3  | RxBwMantAfc          | rw   | 01               | RxBwMant parameter used during the AFC                                                                                                                                                                                                                                                                                                                                        |
|                      | 2-0  | RxBwExpAfc           | rw   | 011*             | RxBwExp parameter used during the AFC                                                                                                                                                                                                                                                                                                                                         |
| RegOokPeak<br>(0x1B) | 7-6  | OokThreshType        | rw   | 01               | Selects type of threshold in the OOK data slicer: 00 → Fixed 10 → Average 01 → Peak 11 → Reserved                                                                                                                                                                                                                                                                             |
|                      | 5-3  | OokPeakTheshStep     | rw   | 000              | Size of each decrement of the RSSI threshold in the OOK demodulator: $000 \rightarrow 0.5 \text{ dB}$ $010 \rightarrow 1.5 \text{ dB}$ $100 \rightarrow 3.0 \text{ dB}$ $110 \rightarrow 5.0 \text{ dB}$ $001 \rightarrow 1.0 \text{ dB}$ $001 \rightarrow 1.0 \text{ dB}$ $011 \rightarrow 2.0 \text{ dB}$ $101 \rightarrow 4.0 \text{ dB}$ $111 \rightarrow 6.0 \text{ dB}$ |
|                      | 2-0  | OokPeakThreshDec     | rw   | 000              | Period of decrement of the RSSI threshold in the OOK demodulator:  000 → Once per chip  001 → Once every two chips  010 → Once every four chips  011 → Once every eight chips  100 → Twice in each chip  101 → Four times in each chip  110 → Eight times in each chip  111 → 16 times in each chip                                                                           |
| RegOokAvg<br>(0x1C)  | 7-6  | OokAverageThreshFilt | rw   | 10               | Filter coefficients in Average mode of the OOK demodulator: $00 \rightarrow f_C \approx \text{chip rate } / 32.\pi$ $01 \rightarrow f_C \approx \text{chip rate } / 8.\pi$ $10 \rightarrow f_C \approx \text{chip rate } / 4.\pi$ $11 \rightarrow f_C \approx \text{chip rate } / 2.\pi$                                                                                      |
|                      | 5-0  | _                    | r    | 000000           | Unused                                                                                                                                                                                                                                                                                                                                                                        |
| RegOokFix<br>(0x1D)  | 7-0  | OokFixedThresh       | rw   | 0110<br>(6dB)    | Fixed threshold value (in dB) in the OOK demodulator. Used when <i>OokThresType</i> = 00                                                                                                                                                                                                                                                                                      |

TABLE 5-3: RECEIVER REGISTERS (CONTINUED)

| Name<br>(Address)      | Bits | Variable Name  | Mode | Default<br>Value | Description                                                                                                                                   |
|------------------------|------|----------------|------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| RegAfcFei              | 7    | _              | r    | 0                | Unused                                                                                                                                        |
| (0x1E)                 | 6    | FeiDone        | r    | 0                | 0 → FEI is on-going<br>1 → FEI finished                                                                                                       |
|                        | 5    | FeiStart       | W    | 0                | Triggers a FEI measurement when set. Always reads '0'.                                                                                        |
|                        | 4    | AfcDone        | r    | 1                | 0 → AFC is on-going<br>1 → AFC has finished                                                                                                   |
|                        | 3    | AfcAutoclearOn | rw   | 0                | Only valid if AfcAutoOn is set  0 → AFC register is not cleared before a new AFC phase  1 → AFC register is cleared before a new AFC phase    |
|                        | 2    | AfcAutoOn      | rw   | 0                | <ul> <li>0 → AFC is performed each time         AfcStart is set</li> <li>1 → AFC is performed each time Rx         mode is entered</li> </ul> |
|                        | 1    | AfcClear       | W    | 0                | Clears the <i>AfcValue</i> if set in Rx mode. Always reads '0'.                                                                               |
|                        | 0    | AfcStart       | W    | 0                | Triggers an AFC when set. Always reads '0'.                                                                                                   |
| RegAfcMsb<br>(0x1F)    | 7-0  | AfcValue(15:8) | r    | 0x00             | MSB of the <i>AfcValue</i> , 2's complement format                                                                                            |
| RegAfcLsb (0x20)       | 7-0  | AfcValue(7:0)  | r    | 0x00             | LSB of the AfcValue, 2's complement format  Frequency correction = AfcValue x Fstep                                                           |
| RegFeiMsb<br>(0x21)    | 7-0  | FeiValue(15:8) | r    | _                | MSB of the measured frequency offset, 2's complement                                                                                          |
| RegFeiLsb (0x22)       | 7-0  | FeiValue(7:0)  | r    | _                | LSB of the measured frequency offset,<br>2's complement<br>Frequency error = FeiValue x Fstep                                                 |
| RegRssiConfig          | 7-2  | _              | r    | 000000           | Unused                                                                                                                                        |
| (0x23)                 | 1    | RssiDone       | r    | 1                | → RSSI is on-going     → RSSI sampling is finished, result available                                                                          |
|                        | 0    | RssiStart      | W    | 0                | Trigger a RSSI measurement when set. Always reads '0'.                                                                                        |
| RegRssiValue<br>(0x24) | 7-0  | RssiValue      | r    | 0xFF             | Absolute value of the RSSI in dBm,<br>0.5 dB steps.<br>RSSI = -RssiValue/2 [dBm]                                                              |

# 5.4 IRQ and Pin Mapping Registers

TABLE 5-4: IRQ AND PIN MAPPING REGISTERS

| Name<br>(Address)      | Bits | Variable Name    | Mode  | Default<br>Value | Description                                                                                                                                                                                                             |
|------------------------|------|------------------|-------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RegDioMapping1         | 7-6  | Dio0Mapping      | rw    | 00               |                                                                                                                                                                                                                         |
| (0x25)                 | 5-4  | Dio1Mapping      | rw    | 00               | Mapping of pins DIO0 to DIO5                                                                                                                                                                                            |
|                        | 3-2  | Dio2Mapping      | rw    | 00               |                                                                                                                                                                                                                         |
|                        | 1-0  | Dio3Mapping      | rw    | 00               | See Table 4-2 for mapping in Continuous mode See Table 4-3 for mapping in Packet mode                                                                                                                                   |
| RegDioMapping2         | 7-6  | Dio4Mapping      | rw    | 00               | See Table 4-3 for mapping in Facker mode                                                                                                                                                                                |
| (0x26)                 | 5-4  | Dio5Mapping      | rw    | 00               |                                                                                                                                                                                                                         |
|                        | 3    | _                | r     | 0                | Unused                                                                                                                                                                                                                  |
|                        | 2-0  | ClkOut           | rw    | 111*             | Selects CLKOUT frequency:                                                                                                                                                                                               |
|                        | 2-0  | CikOut           | IW    | 111,             | Selects CEROOT frequency.  000 → FXOSC  001 → FXOSC/2  010 → FXOSC/4  011 → FXOSC/8  100 → FXOSC/16  101 → FXOSC/32  110 → RC (automatically enabled)  111 → OFF                                                        |
| ReglrqFlags1<br>(0x27) | 7    | 7 ModeReady      |       | 1                | Set when the operation mode requested in Mode, is ready - Sleep: Entering Sleep mode - Standby: XO is running - FS: PLL is locked - Rx: RSSI sampling starts Cleared when changing operating mode.                      |
|                        | 6    | RxReady          | r     | 0                | Set in Rx mode, after RSSI, AGC and AFC.<br>Cleared when leaving Rx.                                                                                                                                                    |
|                        | 5    | _                | r     | 0                | Unused                                                                                                                                                                                                                  |
|                        | 4    | PllLock          | r     | 0                | Set (in FS and Rx) when the PLL is locked.<br>Cleared when it is not.                                                                                                                                                   |
|                        | 3    | Rssi             | rwc   | 0                | Set in Rx when the RssiValue exceeds RssiThreshold. Cleared when leaving Rx.                                                                                                                                            |
|                        | 2    | Timeout          | r     | 0                | Set when a time-out occurs (see <i>TimeoutRxStart</i> and <i>TimeoutRssiThresh</i> ) Cleared when leaving Rx or FIFO is emptied.                                                                                        |
|                        | 1    | AutoMode         | r     | 0                | Set when entering Intermediate mode. Cleared when exiting Intermediate mode. Please note that in Sleep mode a small delay can be observed between <i>AutoMode</i> interrupt and the corresponding Enter/Exit condition. |
|                        | 0    | SyncAddressMatch | r/rwc | 0                | Set when sync and address (if enabled) are detected. Cleared when leaving Rx or FIFO is emptied. This bit is read-only in Packet mode, rwc in Continuous mode.                                                          |

TABLE 5-4: IRQ AND PIN MAPPING REGISTERS (CONTINUED)

|                         | 1    |                   | i    | 1                | 1                                                                                                                                                                                                 |
|-------------------------|------|-------------------|------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Name<br>(Address)       | Bits | Variable Name     | Mode | Default<br>Value | Description                                                                                                                                                                                       |
| ReglrqFlags2 (0x28)     | 7    | FifoFull          | r    | 0                | Set when FIFO is full (i.e., contains 66 bytes), else cleared.                                                                                                                                    |
|                         | 6    | FifoNotEmpty      | r    | 0                | Set when FIFO contains at least one byte, else cleared                                                                                                                                            |
|                         | 5    | FifoLevel         | r    | 0                | Set when the number of bytes in the FIFO strictly exceeds <i>FifoThreshold</i> , else cleared.                                                                                                    |
|                         | 4    | FifoOverrun       | rwc  | 0                | Set when FIFO overrun occurs. (except in Sleep mode) Flag(s) and FIFO are cleared when this bit is set. The FIFO then becomes immediately available for the next reception.                       |
|                         | 3    | _                 | r    | 0                | Unused                                                                                                                                                                                            |
|                         | 2    | PayloadReady      | r    | 0                | Set in Rx when the payload is ready (i.e., last byte received and CRC is OK if enabled and CrcAutoClearOff is cleared). Cleared when FIFO is empty.                                               |
|                         | 1    | CrcOk             | r    | 0                | Set in Rx when the CRC of the payload is OK. Cleared when FIFO is empty.                                                                                                                          |
|                         | 0    | LowBat            | rwc  | _                | Set when the battery voltage drops below the low battery threshold. Cleared only when set by the user.                                                                                            |
| RegRssiThresh (0x29)    | 7-0  | RssiThreshold     | rw   | 0xE4*            | RSSI trigger level for <i>Rssi</i> interrupt: - <i>RssiThreshold  </i> 2 [dBm]                                                                                                                    |
| RegRxTimeout1 (0x2A)    | 7-0  | TimeoutRxStart    | rw   | 0x00             | Time-out interrupt is generated TimeoutRxStart*16*T <sub>bit</sub> after switching to Rx mode if Rssi interrupt does not occur (i.e., RssiValue > RssiThreshold) 0x00: TimeoutRxStart is disabled |
| RegRxTimeout2<br>(0x2B) | 7-0  | TimeoutRssiThresh | rw   | 0x00             | Time-out interrupt is generated TimeoutRssiThresh*16*T <sub>bit</sub> after Rssi interrupt if PayloadReady interrupt does not occur. 0x00: TimeoutRssiThresh is disabled                          |

# 5.5 Packet Engine Registers

TABLE 5-5: PACKET ENGINE REGISTERS

| Name<br>(Address)    | Bits | Variable Name     | Mode | Default<br>Value | Description                                                                                           |
|----------------------|------|-------------------|------|------------------|-------------------------------------------------------------------------------------------------------|
| Reserved2C<br>(0x2c) | 7-0  | _                 | rw   | 0x00             | Unused                                                                                                |
| Reserved2D<br>(0x2d) | 7-0  | _                 | rw   | 0x03             | Unused                                                                                                |
| RegSyncConfig (0x2e) | 7    | SyncOn            | rw   | 1                | Enables the sync word detection:  0 → OFF  1 → ON                                                     |
|                      | 6    | FifoFillCondition | rw   | 0                | FIFO filling condition:  0 → If SyncAddress interrupt occurs  1 → As long as FifoFillCondition is set |
|                      | 5-3  | SyncSize          | rw   | 011              | Size of the sync word:<br>(SyncSize + 1) bytes                                                        |
|                      | 2-0  | SyncTol           | rw   | 000              | Number of tolerated bit errors in sync word                                                           |
| RegSyncValue1 (0x2f) | 7-0  | SyncValue(63:56)  | rw   | 0x01*            | First byte of sync word (MSB byte) Used if SyncOn is set.                                             |
| RegSyncValue2 (0x30) | 7-0  | SyncValue(55:48)  | rw   | 0x01*            | Second byte of sync word Used if SyncOn is set and (SyncSize +1) >= 2.                                |
| RegSyncValue3 (0x31) | 7-0  | SyncValue(47:40)  | rw   | 0x01*            | Third byte of sync word. Used if SyncOn is set and (SyncSize +1) >= 3.                                |
| RegSyncValue4 (0x32) | 7-0  | SyncValue(39:32)  | rw   | 0x01*            | Forth byte of sync word. Used if SyncOn is set and (SyncSize +1) >= 4.                                |
| RegSyncValue5 (0x33) | 7-0  | SyncValue(31:24)  | rw   | 0x01*            | Fifth byte of sync word. Used if SyncOn is set and (SyncSize +1) >= 5.                                |
| RegSyncValue6 (0x34) | 7-0  | SyncValue(23:16)  | rw   | 0x01*            | Sixth byte of sync word. Used if SyncOn is set and (SyncSize +1) >= 6.                                |
| RegSyncValue7 (0x35) | 7-0  | SyncValue(15:8)   | rw   | 0x01*            | Seventh byte of sync word. Used if SyncOn is set and (SyncSize +1) >= 7.                              |
| RegSyncValue8 (0x36) | 7-0  | SyncValue(7:0)    | rw   | 0x01*            | Eighth byte of sync word. Used if SyncOn is set and (SyncSize +1) = 8.                                |

TABLE 5-5: PACKET ENGINE REGISTERS (CONTINUED)

| Name<br>(Address)       | Bits | Variable Name    | Mode | Default<br>Value | Description                                                                                                                                                                                                 |
|-------------------------|------|------------------|------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RegPacketConfig1 (0x37) | 7    | PacketFormat     | rw   | 0                | Defines the packet format used:  0 → Fixed length  1 → Variable length                                                                                                                                      |
|                         | 6-5  | DcFree           | rw   | 00               | Defines DC-free decoding performed:  00 → None (OFF)  01 → Manchester  10 → Whitening  11 → Reserved                                                                                                        |
|                         | 4    | CrcOn            | rw   | 1                | Enables CRC check: 0 → OFF 1 → ON                                                                                                                                                                           |
|                         | 3    | CrcAutoClearOff  | rw   | 0                | Defines the behavior of the packet handler when CRC check fails:  0 → Clear FIFO and restart new packet reception. No PayloadReady interrupt issued.  1 → Do not clear FIFO. PayloadReady interrupt issued. |
|                         | 2-1  | AddressFiltering | rw   | 00               | Defines address based filtering in Rx:  00 → None (OFF)  01 → Address field must match NodeAddress  10 → Must match NodeAddress or  BroadcastAddress  11 → Reserved                                         |
|                         | 0    | _                | rw   | 0                | Unused                                                                                                                                                                                                      |
| RegPayloadLength (0x38) | 7-0  | PayloadLength    | rw   | 0x40             | If PacketFormat = 0 (fixed), payload length If PacketFormat = 1 (variable), max length in Rx                                                                                                                |
| RegNodeAdrs<br>(0x39)   | 7-0  | NodeAddress      | rw   | 0x00             | Node address used in address filtering.                                                                                                                                                                     |
| RegBroadcastAdrs (0x3A) | 7-0  | BroadcastAddress | rw   | 0x00             | Broadcast address used in address filtering.                                                                                                                                                                |

TABLE 5-5: PACKET ENGINE REGISTERS (CONTINUED)

| Name<br>(Address)       | Bits | Variable Name      | Mode | Default<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------------|------|--------------------|------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RegAutoModes<br>(0x3B)  | 7-5  | EnterCondition     | rw   | 000              | Interrupt condition for entering the Intermediate mode:  000 → None (AutoModes OFF)  001 → Rising edge of FifoNotEmpty  010 → Rising edge of FifoLevel  011 → Rising edge of CrcOk  100 → Rising edge of PayloadReady  101 → Rising edge of SyncAddress  110 → Reserved  111 → Falling edge of FifoNotEmpty (i.e., FIFO                                                      |
|                         | 4-2  | ExitCondition      | rw   | 000              | empty)  Interrupt condition for exiting the Intermediate mode:  000 → None (AutoModes OFF)  001 → Falling edge of FifoNotEmpty (i.e., FIFO empty)  010 → Rising edge of FifoLevel or Timeout  011 → Rising edge of CrcOk or Timeout  100 → Rising edge of PayloadReady or Timeout  101 → Rising edge of SyncAddress or Timeout  101 → Reserved  111 → Rising edge of Timeout |
|                         | 1-0  | IntermediateMode   | rw   | 00               | Intermediate mode:  00 → Sleep mode (SLEEP)  01 → Standby mode (STDBY)  10 → Receiver mode (RX)  11 → Reserved                                                                                                                                                                                                                                                               |
| RegFifoThresh           | 7    | _                  | rw   | 1*               | Unused                                                                                                                                                                                                                                                                                                                                                                       |
| (0x3C)                  | 6-0  | FifoThreshold      | rw   | 0001111          | Used to trigger FifoLevel interrupt.                                                                                                                                                                                                                                                                                                                                         |
| RegPacketConfig2 (0x3D) | 7-4  | InterPacketRxDelay | rw   | 0000             | After PayloadReady occurred, defines the delay between FIFO empty and the start of a new RSSI phase for next packet. Must match the transmitter's PA ramp-down time.  - Tdelay = 0 if InterpacketRxDelay >= 12  - Tdelay = (2InterpacketRxDelay) / BitRate otherwise                                                                                                         |
|                         | 3    | _                  | rw   | 0                | Unused                                                                                                                                                                                                                                                                                                                                                                       |
|                         | 2    | RestartRx          | w    | 0                | Forces the receiver in Wait mode, in Continuous Rx mode. Always reads '0'.                                                                                                                                                                                                                                                                                                   |
|                         | 1    | AutoRxRestartOn    | rw   | 1                | Enables automatic Rx restart (RSSI phase) after  PayloadReady occurred and packet has been  completely read from FIFO:  0 → OFF. RestartRx can be used.  1 → ON. Rx auto. restart after  InterPacketRxDelay.                                                                                                                                                                 |
|                         | 0    | AesOn              | rw   | 0                | Enable the AES decryption:  0 → OFF  1 → ON (payload limited to 66 bytes maximum)                                                                                                                                                                                                                                                                                            |
| RegAesKey1<br>(0x3E)    | 7-0  | AesKey(127:120)    | W    | 0x00             | First byte of cipher key (MSB byte)                                                                                                                                                                                                                                                                                                                                          |
| RegAesKey2<br>(0x3F)    | 7-0  | AesKey(119:112)    | W    | 0x00             | Second byte of cipher key                                                                                                                                                                                                                                                                                                                                                    |
| RegAesKey3<br>(0x40)    | 7-0  | AesKey(111:104)    | W    | 0x00             | Third byte of cipher key                                                                                                                                                                                                                                                                                                                                                     |

# TABLE 5-5: PACKET ENGINE REGISTERS (CONTINUED)

| Name<br>(Address)     | Bits | Variable Name  | Mode | Default<br>Value | Description                             |
|-----------------------|------|----------------|------|------------------|-----------------------------------------|
| RegAesKey4<br>(0x41)  | 7-0  | AesKey(103:96) | W    | 0x00             | Forth byte of cipher key                |
| RegAesKey5<br>(0x42)  | 7-0  | AesKey(95:88)  | W    | 0x00             | Fifth byte of cipher key                |
| RegAesKey6<br>(0x43)  | 7-0  | AesKey(87:80)  | w    | 0x00             | Sixth byte of cipher key                |
| RegAesKey7<br>(0x44)  | 7-0  | AesKey(79:72)  | w    | 0x00             | Seventh byte of cipher key              |
| RegAesKey8<br>(0x45)  | 7-0  | AesKey(71:64)  | w    | 0x00             | Eighth byte of cipher key               |
| RegAesKey9<br>(0x46)  | 7-0  | AesKey(63:56)  | w    | 0x00             | Ninth byte of cipher key                |
| RegAesKey10<br>(0x47) | 7-0  | AesKey(55:48)  | w    | 0x00             | Tenth byte of cipher key                |
| RegAesKey11<br>(0x48) | 7-0  | AesKey(47:40)  | w    | 0x00             | Eleventh byte of cipher key             |
| RegAesKey12<br>(0x49) | 7-0  | AesKey(39:32)  | w    | 0x00             | Twelfth byte of cipher key              |
| RegAesKey13<br>(0x4A) | 7-0  | AesKey(31:24)  | w    | 0x00             | Thirteenth byte of cipher key           |
| RegAesKey14<br>(0x4B) | 7-0  | AesKey(23:16)  | w    | 0x00             | Fourteenth byte of cipher key           |
| RegAesKey15<br>(0x4C) | 7-0  | AesKey(15:8)   | w    | 0x00             | Fifteenth byte of cipher key            |
| RegAesKey16<br>(0x4D) | 7-0  | AesKey(7:0)    | w    | 0x00             | Sixteenth byte of cipher key (LSB byte) |

# 5.6 Temperature Sensor Registers

TABLE 5-6: TEMPERATURE SENSOR REGISTERS

| Name<br>(Address)  | Bits | Variable Name   | Mode | Default<br>Value | Description                                                                                                                                                                           |
|--------------------|------|-----------------|------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RegTemp1           | 7-4  | _               | r    | 0000             | Unused                                                                                                                                                                                |
| (0x4E)             | 3    | TempMeasStart   | w    | 0                | Triggers the temperature measurement when set. Always reads 0.                                                                                                                        |
|                    | 2    | TempMeasRunning | r    | 0                | Set to 1 while the temperature measure-<br>ment is running. Toggles back to 0 when the<br>measurement has completed. The receiver<br>can not be used while measuring tempera-<br>ture |
|                    | 1-0  | _               | r    | 01               | Unused                                                                                                                                                                                |
| RegTemp2<br>(0x4F) | 7-0  | TempValue       | r    | _                | Measured temperature -1°C per Lsb Needs calibration for accuracy                                                                                                                      |

# 5.7 Test Registers

TABLE 5-7: TEST REGISTERS

| Name<br>(Address)     | Bits | Variable Name    | Mode | Default<br>Value | Description                                                                                                                                                                               |
|-----------------------|------|------------------|------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RegTestLna<br>(0x58)  | 7-0  | SensitivityBoost | rw   | 0x1B             | High Sensitivity or Normal Sensitivity mode:<br>0x1B → Normal mode<br>0x2D → High Sensitivity mode                                                                                        |
| RegTestTcxo           | 7-5  | Reserved         | rw   | 0x00             | Reserved                                                                                                                                                                                  |
| (0x59)                | 4    | TcxoInputOn      | rw   | 0x00             | Controls the crystal oscillator  0 → Crystal oscillator with external crystal  1 → External clipped sine TCXO ac coupled to XTA pin                                                       |
|                       | 3-0  | Reserved         | rw   | 0x09             | Reserved                                                                                                                                                                                  |
| RegTestPIIBW (0x5F)   | 3-2  | PIIBW            | rw   | 0x02             | PLL 3 dB BW setting<br>0x00 →75 kHz<br>0x01 →150 kHz<br>0x10 →300 kHz<br>0x11 →600 kHz                                                                                                    |
| RegTestDagc<br>(0x6F) | 7-0  | ContinuousDagc   | rw   | 0x30<br>*        | Fading Margin Improvement (see  Section 2.4.3 "Continuous-Time DAGC")  0x00 → Normal mode  0x20 → Improved margin, use if  AfcLowBetaOn=1  0x30 → Improved margin, use if  AfcLowBetaOn=0 |
| RegTestAfc<br>(0x71)  | 7-0  | LowBetaAfcOffset | rw   | 0x00             | AFC offset set for low modulation index systems, used if <i>AfcLowBetaOn</i> = 1. Offset = LowBetaAfcOffset x 488 Hz                                                                      |

# 6.0 APPLICATION INFORMATION

# 6.1 Crystal Resonator Specification

Table 6-1 shows the crystal resonator specification for the crystal reference oscillator circuit of the MRF39RA. This specification covers the full range of operation of the MRF39RA and is employed in the reference design.

TABLE 6-1: CRYSTAL SPECIFICATION

| Symbol | Description               | Conditions              | Min. | Тур. | Max. | Unit |
|--------|---------------------------|-------------------------|------|------|------|------|
| FXOSC  | XTAL Frequency            | _                       | 26   | _    | 32   | MHz  |
| RS     | XTAL Serial Resistance    | _                       | _    | 30   | 140  | ohms |
| C0     | XTAL Shunt Capacitance    | _                       | _    | 2.8  | 7    | pF   |
| CLOAD  | External Foot Capacitance | On each pin XTA and XTB | 8    | 16   | 22   | pF   |

- Note 1: The initial frequency tolerance, temperature stability and aging performance should be chosen in accordance with the target operating temperature range and the receiver bandwidth selected.
  - **2:** The loading capacitance should be applied externally and adapted to the actual CLOAD specification of the XTAL.
  - 3: A minimum XTAL frequency of 28 MHz is required to cover the 863-870 MHz band, 29 MHz for the 902-928 MHz band.

# 6.2 Reset of the Chip

A Power-on Reset of the MRF39RA is triggered at power-up. Additionally, a manual Reset can be issued by controlling pin 6.

#### 6.2.1 POR

If the application requires the disconnection of VDD from the MRF39RA, despite the extremely low Sleep mode current, the user should wait for 10 ms from the end of the POR cycle before commencing communications over the SPI bus. Pin 6 (RESET) should be left floating during the POR sequence.

FIGURE 6-1: POR TIMING DIAGRAM



Please note that any CLKOUT activity can also be used to detect that the chip is ready.

### 6.2.2 MANUAL RESET

A manual Reset of the MRF39RA is possible even for applications in which VDD cannot be physically disconnected. Pin 6 should be pulled high for 100  $\mu$ s and then released. The user should then wait for 5 ms before using the chip.

FIGURE 6-2: MANUAL RESET TIMING DIAGRAM



**Note:** While pin 6 is driven high, an overcurrent consumption of up to 10 mA can be seen on VDD.

# 6.3 Reference Design

Please contact the Microchip representative for evaluation tools, reference designs and design assistance. Note that all schematics shown in this section are full schematics, listing all required components, including decoupling capacitors.

FIGURE 6-3: APPLICATION SCHEMATIC



# TABLE 6-2: REFERENCE BILL OF MATERIALS

| Designator     | 315 MHz | 433 MHz | 868 MHz               | 915 MHz    | Туре                                 |  |
|----------------|---------|---------|-----------------------|------------|--------------------------------------|--|
| C3, C4, C5, C8 |         | 100 nF  |                       |            | X7R                                  |  |
| C6, C7         |         | 15      | pF                    |            | COG                                  |  |
| L1             | 39 nH   | 33 nH   | 120 nH                | 120 nH     | Wirewound air core or multilayer (1) |  |
| C1             | _       | _       | 5.6 pF                | 5.6 pF     | COG                                  |  |
| C2             | 12 pF   | 12 pF   | 6.8 nH <sup>(2)</sup> | 5.6 nH (2) | See above (L or C)                   |  |

Note 1: Inductor values may change when using multilayer type components.

**2:** An additional DC-cut capacitor (typ. 47 pF) might be required with this matching topology and DC grounded antennas.

# 7.0 ELECTRICAL SPECIFICATIONS

# 7.1 Absolute Maximum Ratings<sup>(†)</sup>

Stresses above the values listed below may cause permanent device failure. Exposure to absolute maximum ratings for extended periods may affect device reliability.

TABLE 7-1: ABSOLUTE MAXIMUM RATINGS

| Symbol | Description          | Min. | Max. | Unit |
|--------|----------------------|------|------|------|
| VDDmr  | Supply Voltage       | -0.5 | 3.9  | V    |
| Tmr    | Temperature          | -55  | +115 | °C   |
| Tj     | Junction temperature | _    | +125 | °C   |
| Pmr    | RF Input Level       | _    | +6   | dBm  |

# 7.2 Operating Range

TABLE 7-2: OPERATING RANGE

| Symbol | Description                       | Min. | Max. | Unit |
|--------|-----------------------------------|------|------|------|
| VDDop  | Supply voltage                    | 1.8  | 3.6  | V    |
| Тор    | Operational temperature range     | -40  | +85  | °C   |
| Clop   | Load capacitance on digital ports | _    | 25   | pF   |
| ML     | RF Input Level                    | _    | 0    | dBm  |

### 7.3 ESD Notice

MRF39RA is a high-performance radio frequency device:

- Class 2 of the JEDEC<sup>®</sup> standard JESD22-A114-B (Human Body Model) on all pins
- Class B of the JEDEC standard JESD22-A115-A (Machine Model) on all pins
- Class IV of the JEDEC standard JESD22-C101C (Charged Device Model) on pins 2, 3, 21, 23, 24, Class III on all other pins

It should thus be handled with all the necessary ESD precautions to avoid any permanent damage.

# 7.4 Device Specification

The tables below give the electrical specifications of the receiver under the following conditions:

- Supply voltage VBAT1 = VBAT2 = VDD = 3.3V
- Temperature = 25°C
- FXOSC = 32 MHz
- FRF = 915 MHz
- · 2-level FSK modulation without pre-filtering
- Bit Rate = 4.8 kbps and terminated in a matched 50-Ohm impedance, unless otherwise specified

**Note:** Unless otherwise specified, the performance in the other frequency bands is similar or better.

# 7.4.1 POWER CONSUMPTION

### TABLE 7-3: POWER CONSUMPTION SPECIFICATION

| Symbol  | Description                        | Conditions                 | Min. | Тур. | Max. | Unit |
|---------|------------------------------------|----------------------------|------|------|------|------|
| IDDSL   | Supply current in Sleep mode       | _                          | _    | 0.1  | 1    | uA   |
| IDDIDLE | Supply current in Idle mode        | RC oscillator enabled      | _    | 1.2  | _    | uA   |
| IDDST   | Supply current in Standby mode     | Crystal oscillator enabled | _    | 1.25 | 1.5  | mA   |
| IDDFS   | Supply current in Synthesizer mode | _                          | _    | 9    | _    | mA   |
| IDDR    | Supply current in Receive mode     | _                          |      | 16   | _    | mA   |

# 7.4.2 FREQUENCY SYNTHESIS

# TABLE 7-4: FREQUENCY SYNTHESIZER SPECIFICATION

| Symbol | Description                                          | Conditions                                        | Min. | Тур. | Max.   | Unit |
|--------|------------------------------------------------------|---------------------------------------------------|------|------|--------|------|
| FR     | Synthesizer frequency range                          | Programmable                                      | 290  | _    | 340    | MHz  |
|        |                                                      |                                                   | 424  | _    | 510    | MHz  |
|        |                                                      |                                                   | 862  | _    | 1020   | MHz  |
| FXOSC  | Crystal oscillator frequency                         | See Section 6.1 "Crystal Resonator Specification" | _    | 32   | l      | MHz  |
| TS_OSC | Crystal oscillator wake-up time                      |                                                   | _    | 250  | 500    | μs   |
| TS_FS  | Frequency synthesizer wake-up time to PllLock signal | From Standby mode                                 | _    | 80   | 150    | μs   |
| TS_HOP | Frequency synthesizer hop                            | 200 kHz step                                      | _    | 20   | _      | μs   |
|        | time at most 10 kHz away from                        | 1 MHz step                                        | _    | 20   | _      | μs   |
|        | the target                                           | 5 MHz step                                        | _    | 50   | _      | μs   |
|        |                                                      | 7 MHz step                                        | _    | 50   | _      | μs   |
|        |                                                      | 12 MHz step                                       | _    | 80   | _      | μs   |
|        |                                                      | 20 MHz step                                       | _    | 80   | _      | μs   |
|        |                                                      | 25 MHz step                                       | _    | 80   |        | μs   |
| FSTEP  | Frequency synthesizer step                           | FSTEP = FXOSC/2 <sup>19</sup>                     | _    | 61.0 |        | Hz   |
| FRC    | RC Oscillator frequency                              | After calibration                                 | _    | 62.5 | _      | kHz  |
| BRF    | Bit rate, FSK                                        | Programmable                                      | 1.2  | _    | 300    | kbps |
| BRO    | Bit rate, OOK                                        | Programmable                                      | 1.2  | _    | 32.768 | kbps |

# 7.4.3 RECEIVER

All receiver tests are performed with RxBw = 10 kHz (Single Side Bandwidth) as programmed in RegRxBw, receiving a PN15 sequence with a BER of 0.1% (bit synchronizer is enabled), unless otherwise specified. The LNA impedance is set to 200 Ohms, by setting bit LnaZin in RegLna to '1'. Blocking tests are performed with an unmodulated interferer. The wanted signal power for the blocking immunity, ACR, IIP2, IIP3 and AMR tests is set 3 dB above the nominal sensitivity level.

**TABLE 7-5: RECEIVER SPECIFICATION** 

| Symbol        | Description                                                                           | Conditions                                                      | Min.        | Тур.           | Max.        | Unit           |
|---------------|---------------------------------------------------------------------------------------|-----------------------------------------------------------------|-------------|----------------|-------------|----------------|
| RFS_F         | FSK sensitivity, highest LNA gain                                                     | FDA = 5 kHz, BR = 1.2 kbps<br>FDA = 5 kHz, BR = 4.8 kbps        | _           | -118<br>-114   | _           | dBm<br>dBm     |
|               |                                                                                       | FDA = 40 kHz, BR = 38.4 kbps                                    | _           | -105           | _           | dBm            |
|               |                                                                                       | FDA = 5 kHz, BR = 1.2 kbps <sup>(1)</sup>                       | _           | -120           | _           | dBm            |
| RFS_O         | OOK sensitivity, highest LNA gain                                                     | BR = 4.8 kbps                                                   | _           | -112           | -109        | dBm            |
| CCR           | Co-channel rejection                                                                  | _                                                               | -13         | -10            | _           | dB             |
| ACR           | Adjacent channel rejection                                                            | Offset = +/- 25 kHz<br>Offset = +/- 50 kHz                      | <br>37      | 42<br>42       | _           | dB<br>dB       |
| ВІ            | Blocking immunity                                                                     | Offset = +/- 1 MHz<br>Offset = +/- 2 MHz<br>Offset = +/- 10 MHz |             | 66<br>71<br>79 |             | dB<br>dB<br>dB |
|               | Blocking immunity<br>Wanted signal at sensitivity<br>+16 dB                           | Offset = +/- 1 MHz<br>Offset = +/- 2 MHz<br>Offset = +/- 10 MHz | _<br>_<br>_ | 62<br>65<br>73 | _<br>_<br>_ | dB<br>dB<br>dB |
| AMR           | AM Rejection, AM modulated interferer with 100% modulation depth, fm = 1 kHz, square  | Offset = +/- 1 MHz<br>Offset = +/- 2 MHz<br>Offset = +/- 10 MHz | _<br>_<br>_ | 66<br>71<br>79 | _<br>_<br>_ | dB<br>dB<br>dB |
| IIP2          | Second order input intercept point Unwanted tones are 20 MHz above the LO             | Lowest LNA gain<br>Highest LNA gain                             | _           | +75<br>+35     | _           | dBm<br>dBm     |
| IIP3          | Third order input intercept point Unwanted tones are 1 MHz and 1.995 MHz above the LO | Lowest LNA gain<br>Highest LNA gain                             | <br>-23     | +20<br>-18     | _           | dBm<br>dBm     |
| BW_SSB        | Single side channel filter BW                                                         | Programmable                                                    | 2.6         | _              | 500         | kHz            |
| IMR_OOK       | Image rejection in OOK mode                                                           | Wanted signal level = -106 dBm                                  | 27          | 30             | _           | dB             |
| TS_RE         | Receiver wake-up time, from PLL locked state to RxReady                               | RxBw = 10 kHz, BR = 4.8 kbps<br>RxBw = 200 kHz, BR = 100 kbps   | _           | 1.7<br>96      | _           | ms<br>µs       |
| TS_RE_AGC     | Receiver wake-up time, from PLL locked state, AGC enabled                             | RxBw= 10 kHz, BR = 4.8 kbps<br>RxBw = 200 kHz, BR = 100 kbps    | _           | 3.0<br>163     | _           | ms<br>µs       |
| TS_RE_AGC&AFC | Receiver wake-up time, from PLL lock state, AGC and AFC enabled                       | RxBw= 10 kHz, BR = 4.8 kbs<br>RxBw = 200 kHz, BR = 100 kbs      | _           | 4.8<br>265     | _           | ms<br>µs       |

Note 1: Set SensitivityBoost in RegTestLna to 0x2D to reduce the noise floor in the receiver.

TABLE 7-5: RECEIVER SPECIFICATION (CONTINUED)

| Symbol  | Description        | Conditions        | Min. | Тур.               | Max. | Unit |
|---------|--------------------|-------------------|------|--------------------|------|------|
| TS_FEI  | FEI sampling time  | Receiver is ready | _    | 4.T <sub>bit</sub> | _    | _    |
| TS_AFC  | AFC response time  | Receiver is ready | _    | 4.T <sub>bit</sub> | _    | _    |
| TS_RSSI | RSSI response time | Receiver is ready | _    | 2.T <sub>bit</sub> | _    | _    |
| DR_RSSI | RSSI dynamic range | AGC enabled       |      |                    |      |      |
|         |                    | Min.              | _    | -115               | _    | dBm  |
|         |                    | Max.              |      | 0                  |      | dBm  |

**Note 1:** Set SensitivityBoost in RegTestLna to 0x2D to reduce the noise floor in the receiver.

# 7.4.4 DIGITAL SPECIFICATION

# **TABLE 7-6: DIGITAL SPECIFICATION**

| Operating Conditions (unless otherwise specified) Temperature: 25°C, VDD = 3.3V, FXOSC = 32 MHz |                                    |                                                       |      |      |      |       |
|-------------------------------------------------------------------------------------------------|------------------------------------|-------------------------------------------------------|------|------|------|-------|
| Symbol                                                                                          | Description                        | Conditions                                            | Min. | Тур. | Max. | Units |
| V <sub>IH</sub>                                                                                 | Digital input level high           | _                                                     | 8.0  | _    | _    | VDD   |
| $V_{IL}$                                                                                        | Digital input level low            | _                                                     |      | _    | 0.2  | VDD   |
| $V_{OH}$                                                                                        | Digital output level high          | IMAX = 1 mA                                           | 0.9  | _    | _    | VDD   |
| $V_{OL}$                                                                                        | Digital output level low           | IMAX = -1 mA                                          | _    | _    | 0.1  | VDD   |
| F <sub>SCK</sub>                                                                                | SCK frequency                      | _                                                     | _    | _    | 10   | MHz   |
| t <sub>ch</sub>                                                                                 | SCK high time                      | _                                                     | 50   | _    | _    | ns    |
| t <sub>cl</sub>                                                                                 | SCK low time                       | _                                                     | 50   | _    | _    | ns    |
| t <sub>rise</sub>                                                                               | SCK rise time                      | _                                                     | _    | 5    | _    | ns    |
| t <sub>fall</sub>                                                                               | SCK fall time                      | _                                                     |      | 5    | _    | ns    |
| t <sub>setup</sub>                                                                              | MOSI setup time                    | From MOSI change to SCK rising edge                   | 30   | _    | _    | ns    |
| t <sub>hold</sub>                                                                               | MOSI hold time                     | From SCK rising edge to MOSI change                   | 60   | _    | _    | ns    |
| t <sub>nsetup</sub>                                                                             | NSS setup time                     | From NSS falling edge to SCK rising edge              | 30   | _    | _    | ns    |
| t <sub>nhold</sub>                                                                              | NSS hold time                      | From SCK falling edge to NSS rising edge, Normal mode | 100  | _    | _    | ns    |
| t <sub>nhigh</sub>                                                                              | NSS high time between SPI accesses | _                                                     | 20   | _    | _    | ns    |
| T_DATA                                                                                          | DATA hold and setup time           | _                                                     | 250  | _    | _    | ns    |

# 8.0 PACKAGING INFORMATION

# 8.1 Package Marking Information

24-Lead QFN (5x5x0.9 mm)





**Legend:** XX...X Customer-specific information

Y Year code (last digit of calendar year)
YY Year code (last 2 digits of calendar year)
WW Week code (week of January 1 is week '01')

NNN Alphanumeric traceability code

e3 Pb-free JEDEC® designator for Matte Tin (Sn)

This package is Pb-free. The Pb-free JEDEC designator (e3)

can be found on the outer packaging for this package.

**Note**: In the event the full Microchip part number cannot be marked on one line, it will be carried over to the next line, thus limiting the number of available characters for customer-specific information.

© 2014 Microchip Technology Inc.

# 8.2 Package Details

The following sections give the technical details of the packages.

# 24-Lead Plastic Quad Flat, No Lead Package (LY) – 5x5x1.0 mm Body [QFN or VQFN]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



Microchip Technology Drawing C04-364A Sheet 1 of 2

# 24-Lead Plastic Quad Flat, No Lead Package (LY) – 5x5x1.0 mm Body [QFN or VQFN]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



| Units                   |      | MILLIMETERS |           |      |  |
|-------------------------|------|-------------|-----------|------|--|
| Dimension Limits        |      | MIN         | NOM       | MAX  |  |
| Number of Terminals     | N    | 24          |           |      |  |
| Pitch                   |      | 0.65 BSC    |           |      |  |
| Overall Height          |      | 0.80        | 0.80 0.90 |      |  |
| Standoff                |      | 0.00        | 0.02      | 0.05 |  |
| Terminal Thickness      | (A3) | 0.20 REF    |           |      |  |
| Overall Width           | Е    | 5.00 BSC    |           |      |  |
| Exposed Pad Width       | E2   | 3.20        | 3.25      | 3.30 |  |
| Overall Length          | D    | 5.00 BSC    |           |      |  |
| Exposed Pad Length      | D2   | 3.20        | 3.25      | 3.30 |  |
| Terminal Width          | b    | 0.25        | 0.30      | 0.35 |  |
| Terminal Length         | Ĺ    | 0.35        | 0.40      | 0.45 |  |
| Terminal-to-Exposed Pad | K    | 0.20        | -         | -    |  |

### Notes:

- 1. Pin 1 visual index feature may vary, but must be located within the hatched area.
- 2. Package is saw singulated.
- 3. Dimensioning and tolerancing per ASME Y14.5M.

BSC: Basic Dimension. Theoretically exact value shown without tolerances.

REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-364A Sheet 2 of 2

# 24-Lead Plastic Quad Flat, No Lead Package (LY) – 5x5x1.0 mm Body [QFN or VQFN]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



# RECOMMENDED LAND PATTERN

| Units                           |    | MILLIMETERS |          |      |  |
|---------------------------------|----|-------------|----------|------|--|
| Dimension Limits                |    | MIN         | NOM      | MAX  |  |
| Contact Pitch                   |    |             | 0.65 BSC |      |  |
| Center Pad Width                | X2 |             |          | 3.30 |  |
| Center Pad Length               | Y2 |             |          | 3.30 |  |
| Contact Pad Spacing             | C1 |             | 4.90     |      |  |
| Contact Pad Spacing             | C2 |             | 4.90     |      |  |
| Contact Pad Width (X24)         | X1 |             |          | 0.35 |  |
| Contact Pad Length (X24)        | Y1 |             |          | 0.80 |  |
| Contact Pad to Center Pad (X24) | G1 | 0.20        |          |      |  |
| Thermal Via Diameter            | V  |             | 0.30     |      |  |
| Thermal Via Pitch               | EV |             | 1.00     |      |  |

### Notes:

1. Dimensioning and tolerancing per ASME Y14.5M

 ${\tt BSC: Basic \ Dimension. \ Theoretically \ exact \ value \ shown \ without \ tolerances.}$ 

Microchip Technology Drawing C04-2364A

# 8.3 Thermal Impedance

The thermal impedance of this package is: Theta ja =  $23.8^{\circ}$ C/W typ., calculated from a package in still air, on a 4-layer FR4 PCB, as per the JEDEC® standard.

# 8.4 Ordering Information

TABLE 1: ORDERING INFORMATION

| Part Number | Delivery    | MOQ/Multiple |  |  |
|-------------|-------------|--------------|--|--|
| MRF39RA     | Tape & Reel | 3000 pieces  |  |  |

• 24-Lead QFN Package

• Operating Range: -40°C, +85°C

- Pb-free
- · Halogen free
- RoHS/WEEE compliant product

APPENDIX A: DATA SHEET

**REVISION HISTORY** 

**Revision A (12/2014)** 

Initial release of this document.

### THE MICROCHIP WEB SITE

Microchip provides online support via our WWW site at www.microchip.com. This web site is used as a means to make files and information easily available to customers. Accessible by using your favorite Internet browser, the web site contains the following information:

- Product Support Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software
- General Technical Support Frequently Asked Questions (FAQ), technical support requests, online discussion groups, Microchip consultant program member listing
- Business of Microchip Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives

# CUSTOMER CHANGE NOTIFICATION SERVICE

Microchip's customer notification service helps keep customers current on Microchip products. Subscribers will receive e-mail notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest.

To register, access the Microchip web site at www.microchip.com. Under "Support", click on "Customer Change Notification" and follow the registration instructions.

### CUSTOMER SUPPORT

Users of Microchip products can receive assistance through several channels:

- · Distributor or Representative
- · Local Sales Office
- Field Application Engineer (FAE)
- · Technical Support

Customers should contact their distributor, representative or Field Application Engineer (FAE) for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in the back of this document.

Technical support is available through the web site at: http://microchip.com/support.

# PRODUCT IDENTIFICATION SYSTEM

 $\underline{\text{To order or obtain information, e.g., on pricing or delivery, refer to the factory or the listed sales of fice.}\\$ 

| PART NO.<br>Device       | [X] <sup>(1)</sup> - X /XX XXX  Tape and Reel Temperature Package Patte Option Range | Examples:  a) MRF39RA - I/LY Industrial temperature, QFN package                                                                                                                                                                                                             |
|--------------------------|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Device:                  | MRF39RA                                                                              |                                                                                                                                                                                                                                                                              |
| Tape and Reel<br>Option: | Blank = Standard packaging (tube or tray) T = Tape and Reel <sup>(1)</sup>           |                                                                                                                                                                                                                                                                              |
| Temperature<br>Range:    | I = $-40^{\circ}$ C to $+85^{\circ}$ C (Industrial)                                  |                                                                                                                                                                                                                                                                              |
| Package: <sup>(2)</sup>  | LY = QFN                                                                             |                                                                                                                                                                                                                                                                              |
| Pattern:                 | QTP, SQTP, Code or Special Requirements (blank otherwise)                            | Note 1: Tape and Reel identifier only appears in the catalog part number description. This identifier is used for ordering purposes and is not printed on the device package. Check with your Microchip Sales Office for package availability with the Tape and Reel option. |
|                          |                                                                                      | <ol> <li>For other small form-factor package<br/>availability and marking information, please<br/>visit www.microchip.com/packaging or<br/>contact your local sales office.</li> </ol>                                                                                       |

#### Note the following details of the code protection feature on Microchip devices:

- · Microchip products meet the specification contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our
  knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data
  Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as "unbreakable."

Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights.

#### **Trademarks**

The Microchip name and logo, the Microchip logo, dsPIC, FlashFlex, flexPWR, JukeBlox, KEELoQ, KEELoQ logo, Kleer, LANCheck, MediaLB, MOST, MOST logo, MPLAB, OptoLyzer, PIC, PICSTART, PIC<sup>32</sup> logo, RightTouch, SpyNIC, SST, SST Logo, SuperFlash and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

The Embedded Control Solutions Company and mTouch are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Analog-for-the-Digital Age, BodyCom, chipKIT, chipKIT logo, CodeGuard, dsPICDEM, dsPICDEM.net, ECAN, In-Circuit Serial Programming, ICSP, Inter-Chip Connectivity, KleerNet, KleerNet logo, MiWi, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, MultiTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, RightTouch logo, REAL ICE, SQI, Serial Quad I/O, Total Endurance, TSHARC, USBCheck, VariSense, ViewSpan, WiperLock, Wireless DNA, and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

Silicon Storage Technology is a registered trademark of Microchip Technology Inc. in other countries.

GestIC is a registered trademarks of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries.

All other trademarks mentioned herein are property of their respective companies.

© 2014, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.

ISBN: 978-1-63276-909-1

# QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV = ISO/TS 16949=

Microchip received ISO/TS-16949:2009 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Gresham, Oregon and design centers in California and India. The Company's quality system processes and procedures are for its PIC® MCUs and dsPIC® DSCs, KEELOQ® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001:2000 certified.



# Worldwide Sales and Service

#### **AMERICAS**

**Corporate Office** 

2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7200

Fax: 480-792-7277 Technical Support:

http://www.microchip.com/ support

Web Address: www.microchip.com

Atlanta

Duluth, GA Tel: 678-957-9614 Fax: 678-957-1455

Austin, TX Tel: 512-257-3370

Boston

Westborough, MA Tel: 774-760-0087 Fax: 774-760-0088

Chicago Itasca, IL

Tel: 630-285-0071 Fax: 630-285-0075

Cleveland

Independence, OH Tel: 216-447-0464 Fax: 216-447-0643

**Dallas** 

Addison, TX Tel: 972-818-7423 Fax: 972-818-2924

Detroit Novi MI

Tel: 248-848-4000

Houston, TX

Tel: 281-894-5983

Noblesville, IN Tel: 317-773-8323 Fax: 317-773-5453

Los Angeles

Mission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608

New York, NY Tel: 631-435-6000

**San Jose, CA** Tel: 408-735-9110

**Canada - Toronto** Tel: 905-673-0699 Fax: 905-673-6509

#### ASIA/PACIFIC

Asia Pacific Office

Suites 3707-14, 37th Floor Tower 6, The Gateway Harbour City, Kowloon Hong Kong

Tel: 852-2943-5100 Fax: 852-2401-3431

Australia - Sydney

Tel: 61-2-9868-6733 Fax: 61-2-9868-6755

China - Beijing

Tel: 86-10-8569-7000 Fax: 86-10-8528-2104

China - Chengdu

Tel: 86-28-8665-5511 Fax: 86-28-8665-7889

China - Chongging

Tel: 86-23-8980-9588 Fax: 86-23-8980-9500

China - Hangzhou

Tel: 86-571-8792-8115 Fax: 86-571-8792-8116

China - Hong Kong SAR

Tel: 852-2943-5100 Fax: 852-2401-3431

China - Nanjing

Tel: 86-25-8473-2460 Fax: 86-25-8473-2470

China - Qingdao

Tel: 86-532-8502-7355 Fax: 86-532-8502-7205

China - Shanghai

Tel: 86-21-5407-5533 Fax: 86-21-5407-5066

China - Shenyang

Tel: 86-24-2334-2829 Fax: 86-24-2334-2393

China - Shenzhen

Tel: 86-755-8864-2200 Fax: 86-755-8203-1760

China - Wuhan

Tel: 86-27-5980-5300 Fax: 86-27-5980-5118

China - Xian

Tel: 86-29-8833-7252 Fax: 86-29-8833-7256

China - Xiamen

Tel: 86-592-2388138 Fax: 86-592-2388130

China - Zhuhai

Tel: 86-756-3210040 Fax: 86-756-3210049

#### ASIA/PACIFIC

India - Bangalore

Tel: 91-80-3090-4444 Fax: 91-80-3090-4123

India - New Delhi

Tel: 91-11-4160-8631 Fax: 91-11-4160-8632

India - Pune

Tel: 91-20-3019-1500

Japan - Osaka

Tel: 81-6-6152-7160 Fax: 81-6-6152-9310

Japan - Tokyo

Tel: 81-3-6880- 3770 Fax: 81-3-6880-3771

Korea - Daegu

Tel: 82-53-744-4301 Fax: 82-53-744-4302

Korea - Seoul

Tel: 82-2-554-7200 Fax: 82-2-558-5932 or

82-2-558-5934

Malaysia - Kuala Lumpur

Tel: 60-3-6201-9857 Fax: 60-3-6201-9859

Malaysia - Penang

Tel: 60-4-227-8870 Fax: 60-4-227-4068

Philippines - Manila

Tel: 63-2-634-9065 Fax: 63-2-634-9069

Singapore

Tel: 65-6334-8870 Fax: 65-6334-8850

Taiwan - Hsin Chu

Tel: 886-3-5778-366 Fax: 886-3-5770-955

Taiwan - Kaohsiung

Tel: 886-7-213-7830

Taiwan - Taipei

Tel: 886-2-2508-8600 Fax: 886-2-2508-0102

Thailand - Bangkok

Tel: 66-2-694-1351 Fax: 66-2-694-1350

#### **EUROPE**

Austria - Wels

Tel: 43-7242-2244-39 Fax: 43-7242-2244-393

Denmark - Copenhagen

Tel: 45-4450-2828 Fax: 45-4485-2829

France - Paris

Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79

Germany - Dusseldorf

Tel: 49-2129-3766400

**Germany - Munich** Tel: 49-89-627-144-0

Fax: 49-89-627-144-44 **Germany - Pforzheim** 

Tel: 49-7231-424750

Italy - Milan

Tel: 39-0331-742611 Fax: 39-0331-466781

Italy - Venice

Tel: 39-049-7625286

Netherlands - Drunen

Tel: 31-416-690399

Fax: 31-416-690340

Poland - Warsaw

Tel: 48-22-3325737

**Spain - Madrid** Tel: 34-91-708-08-90

Fax: 34-91-708-08-91

Sweden - Stockholm

Tel: 46-8-5090-4654 **UK - Wokingham** 

Tel: 44-118-921-5800 Fax: 44-118-921-5820

03/25/14